用python写一个冒泡排序,并写好注释
时间: 2024-03-13 14:30:47 浏览: 39
# 定义一个函数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]
相关问题
用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写一个冒泡排序,并做好注释
# 定义一个冒泡排序函数
def bubble_sort(arr):
# 获取数组长度
n = len(arr)
# 遍历数组元素
for i in range(n):
# 内层循环,每次比较相邻两个元素
for j in range(0, n-i-1):
# 如果前一个元素大于后一个元素,则交换位置
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("原数组:", arr)
sorted_arr = bubble_sort(arr)
print("排序后的数组:", sorted_arr)
# 输出:
# 原数组: [64, 34, 25, 12, 22, 11, 90]
# 排序后的数组: [11, 12, 22, 25, 34, 64, 90]
阅读全文