本文共 706 字,大约阅读时间需要 2 分钟。
"""
冒泡排序
把无序的数组按照从小到大的顺序进行排序
时间复杂度O(n2)
"""
# 创建一个不规则数组
import random
arry = []
# 循环20次
for i in range(20):
# 每次生成一个随机数
arry.append(random.randrange(1000))
# 冒泡排序
def bubble_sort1(data):
for i in range(len(data) - 1):
for j in range(len(data) - 1 - i):
if data[j] > data[j + 1]:
data[j], data[j + 1] = data[j + 1], data[j]
# 冒泡排序 如果没有交换那么排序已经完成。
def bubble_sort2(data):
for i in range(len(data) - 1):
exchange = False
for j in range(len(data) - 1 - i):
if data[j] > data[j + 1]:
data[j], data[j + 1] = data[j + 1], data[j]
exchange = True
if not exchange:
break
# 调用冒泡排序
bubble_sort1(arry)
print(arry)
bubble_sort2(arry)
print(arry)
转载于:https://www.cnblogs.com/mjxup/p/6eb90c468aa981e0210b5ea49495b252.html