冒泡排序
冒泡排序
- 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。
- 针对所有的元素重复以上的步骤,除了最后一个。
- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

pthon 中的交换操作

**使用额外的内存 **
temp = alist[i]
alist[i] = alist[j]
alist[j] = temp
同时赋值
a,b = b,a
冒泡排序实现
def BubbleSort(alist):
leng = len(alist)
#需要循环的次数:n-1
for index in range(leng-1,0,-1):
# 每次循环将当前的最大值放在合适的位置上
for i in range(index):
if alist[i] > alist[i+1]:
temp = alist[i]
alist[i] = alist[i+1]
alist[i + 1] = temp
测试:
alist = [54,26,93,17,77,31,44,55,20]
BubbleSort(alist)
print(alist)
短冒泡排序
def shortBubbleSort(alist):
exchanges = True
passnum = len(alist) - 1
while passnum > 0 and exchanges:
exchanges = False
for i in range(passnum):
if alist[i] > alist[i+1]:
exchanges = True
temp = alist[i]
alist[i] = alist[i+1]
alist[i+1] = temp
passnum -= 1
参考:

浙公网安备 33010602011771号