冒泡排序算法是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
下面是冒泡排序算法的Python实现:
```python
def bubble_sort(arr):
n = len(arr)
for i in range(n):
# 标记当前元素是否应该交换
swapped = False
# 从第一个元素开始,到最后一个元素结束
- for j in range(0, n
- i - 1):
# 如果前一个元素大于后一个元素,交换它们的位置
if arr[j] > arr[j + 1]:
arr[j], arr[j + 1] = arr[j + 1], arr[j]
swapped = True
# 如果在某次循环中没有发生交换,说明数组已经排序完成,可以提前结束循环
if not swapped:
break
return arr
```
这个函数接受一个列表作为输入,然后使用冒泡排序算法对其进行排序。在每次迭代中,它都会检查相邻的元素,如果前一个元素大于后一个元素,就交换它们的位置。这个过程会一直重复,直到整个列表都被排序。
以下是如何使用这个函数的例子:
```python
arr = [64, 34, 25, 12, 22, 11, 90]
sorted_arr = bubble_sort(arr)
print(sorted_arr)
```
输出结果:
```
[11, 12, 22, 25, 34, 64, 90]
```
在这个例子中,输入的列表是`[64, 34, 25, 12, 22, 11, 90]`,经过冒泡排序算法排序后,得到的结果是`[11, 12, 22, 25, 34, 64, 90]`。