用python写一个冒泡排序,并做好注释
时间: 2024-03-13 07:16:56 浏览: 20
冒泡排序是一种简单的排序算法,其基本思想是通过比较相邻元素的大小,将大的元素逐步向后移动,从而实现排序的目的。以下是Python实现冒泡排序的代码:
```python
def bubble_sort(arr):
"""
冒泡排序函数
:param arr: 待排序的数组
:return: 排序后的数组
"""
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]
return arr
```
代码中,外层循环控制排序轮数,内层循环控制每轮比较次数。每轮比较都会将大的元素逐步向后移动,直到最后一个元素为止。
需要注意的是,该实现方式是一种较为基础的冒泡排序实现方式,时间复杂度为O(n^2),如果数据规模较大,效率较低。
相关问题
用python写一个冒泡排序 ,并写好注释
# 冒泡排序算法
def bubble_sort(arr):
n = len(arr)
# 遍历所有数组元素
for i in range(n):
# Last i elements are already in place
for j in range(0, n - i - 1):
# traverse the array from 0 to n-i-1
# Swap if the element found is greater
# than the next element
if arr[j] > arr[j + 1]:
arr[j], arr[j + 1] = arr[j + 1], arr[j]
return arr
# 测试代码
arr = [64, 34, 25, 12, 22, 11, 90]
print("排序前的数组:")
print(arr)
arr = bubble_sort(arr)
print("排序后的数组:")
print(arr)
"""
输出结果:
排序前的数组:
[64, 34, 25, 12, 22, 11, 90]
排序后的数组:
[11, 12, 22, 25, 34, 64, 90]
"""
用python写一个冒泡排序,并写好注释
# 定义一个函数bubble_sort,传入一个列表参数
def bubble_sort(lst):
# 需要遍历多少次列表,即n-1次,n为列表长度
for i in range(len(lst)-1):
# 每次遍历需要比较的次数,即n-i-1次,i为已经排序好的元素个数
for j in range(len(lst)-i-1):
# 如果当前元素比下一个元素大,则交换位置
if lst[j] > lst[j+1]:
lst[j], lst[j+1] = lst[j+1], lst[j]
# 返回排序后的列表
return lst
# 测试排序函数
a = [3, 2, 5, 8, 1, 9, 4]
print(bubble_sort(a)) # 输出[1, 2, 3, 4, 5, 8, 9]