冒泡排序,顾名思义,就是重复地走访过要排序的数列,一次比较两个元素,较大的元素会经由交换慢慢“冒”出来(交换)的一种排序方法。
举栗子: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]
现在有这样一个数列。
首先比较第一位元素和第二位元素。很明显,第二位元素比第一位元素小,于是两者交换,较大的元素始终要排在后面。
然后在比较第二位元素与第三位元素,由于第三位元素比第二位元素大,所以不用交换。但这是第三位元素冒了出来,接下来由第三位元素与第四位元素对比了,以此类推。
然后就用代码实现吧,接下来,我会用非常详细的结果展示排序的过程。
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)
if __name__ == "__main__&#