冒泡排序python实现
时间: 2023-12-28 10:25:49 浏览: 26
冒泡排序是一种简单的排序算法,它重复地遍历要排序的列表,比较相邻的元素,并按照大小交换它们,直到整个列表排序完成。以下是用Python实现冒泡排序的示例代码:
```python
def bubble_sort(arr):
n = len(arr)
for i in range(n-1):
for j in range(n-i-1):
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
# 示例
arr = [64, 34, 25, 12, 22, 11, 90]
bubble_sort(arr)
print("排序后的列表:", arr)
```
输出结果为:[11, 12, 22, 25, 34, 64, 90]
相关问题
双向冒泡排序算法实现冒泡排序python
好的,我可以为您解答关于双向冒泡排序算法实现冒泡排序 Python 的问题。
冒泡排序是一种简单的排序算法,也是常见的排序方式之一。在 Python 中,可以使用双向冒泡排序算法来实现冒泡排序。该算法是在传统的冒泡排序基础上进行了优化,可以减少排序过程中的比较次数和交换次数。
下面是双向冒泡排序算法实现冒泡排序 Python 代码示例:
``` python
def bubble_sort(array):
"""
双向冒泡排序算法实现冒泡排序
"""
n = len(array)
low = 0
high = n - 1
while low <= high:
for i in range(low, high):
if array[i] > array[i+1]:
array[i], array[i+1] = array[i+1], array[i]
high -= 1
for i in reversed(range(low+1, high+1)):
if array[i-1] > array[i]:
array[i], array[i-1] = array[i-1], array[i]
low += 1
return array
```
代码中,首先定义了一个 bubble_sort 函数,该函数接受一个列表作为参数,返回排序后的列表。然后,使用双向冒泡排序算法来实现冒泡排序。其中,low 和 high 分别表示待排序区间的起始和结束位置,初始值为 0 和 n-1。在每一轮排序中,先从左往右遍历,将较大的元素向右交换,然后从右往左遍历,将较小的元素向左交换,直到 low 等于 high。
希望这个回答对您有所帮助。如果您还有其他问题,请随时提出。
冒泡排序用python实现
冒泡排序是一种简单的排序算法,可以用Python来实现。下面是一个用Python实现冒泡排序的例子:
```python
def bubble_sort(a_list):
for pass_num in range(len(a_list) - 1, 0, -1):
for i in range(pass_num):
if a_list[i] > a_list[i + 1]:
temp = a_list[i]
a_list[i] = a_list[i + 1]
a_list[i + 1] = temp
a_list = [54, 26, 93, 17, 77, 31, 44, 55, 20]
bubble_sort(a_list)
print(a_list)
```
这段代码定义了一个名为`bubble_sort`的函数,它接受一个列表作为参数,并对列表进行冒泡排序。在每一轮排序中,它会比较相邻的两个元素,如果它们的顺序不正确,则交换它们的位置。通过多次遍历列表,直到没有需要交换的元素为止,最终得到一个有序的列表。
在上面的例子中,我们使用了一个名为`a_list`的列表作为输入,并调用`bubble_sort`函数对其进行排序。最后,我们打印出排序后的列表。
希望这个例子能帮助你理解冒泡排序的实现过程。