def bubble_sort(alist):
count = 0
for j in range(0,len(alist) - 1):#整个数列排序循环
for i in range(0,len(alist) - 1 - j):
# 元素从头走到尾,走完一次,排好一个数
if alist[i] > alist[i + 1]:
#因为要和下一个数相比,所以i只需要走到len(alist) - 1 - j
alist[i],alist[i + 1] = alist[i + 1],alist[i]
print(alist)
count += 1
print(count)
def bubble_sort2(alist):
"""
第一次交换后,第二位元素本身比第三位元素小,所以不需要交换,但程序还是完整的走完了才进入下一次循环。
所以我们是不是可以在上面的基础上做个改进,当当前元素本身就比下一位元素小,直接进入下一个循环。
"""
count = 0
for j in range(0,len(alist) - 1):#整个数列排序循环
for i in range(0,len(alist) - 1 - j):
# 元素从头走到尾,走完一次,排好一个数
if alist[i] > alist[i + 1]:
#因为要和下一个数相比,所以i只需要走到len(alist) - 1 - j
alist[i],alist[i + 1] = alist[i + 1],alist[i]
else:
continue
print(alist)
count += 1
print(count)
if __name__ == "__main__":
li = [53,26,93,17,77,31,44,55,20,33,2,2,2,3,4,5555,6,6,6,66,67,67,76,77,3,34,34,23,232,3,3]
print(li)
bubble_sort(li)
03-17
730
![](https://csdnimg.cn/release/blogv2/dist/pc/img/readCountBlack.png)
04-04