插入排序:
#插入排序:假使左边元素是有序的,在右边元素中选出元素,与左边的元素进行比较,然后放到恰当的有序位置。思想:从右边选出元素放在左边,使得
#左边部分是有序的,右边元素为空,左边元素有序,排序停止
def insert_sort(alist):
n = len(alist)
#从右边的无序序列中取出多少个元素执行这样的过程
for j in range(1,n):
#i代表的是内层循环起始
i = j
#执行从右边的无序序列中取出第一个元素,即i位置的元素,然后将其插入到前面的正确位置中
while i>0:
if alist[i] < alist[i-1]:
alist[i],alist[i-1] = alist[i-1],alist[i]
i -= 1
else:
break
if __name__=="__main__":
li = [6,5,3,1,8,7,2,4]
print(li)
insert_sort(li)
print(li)
选择排序:
#选择排序 最优最坏时间复杂度都为O(n2)不稳定
def select_sort(alist):
n = len(alist)
for j in range(0,n-1):#j:0-(n-2)
min_index = j
for i in range(j+1,n):
if alist[min_index] > alist[i]:
min_index = i
alist[j],alist[min_index] = alist[min_index],alist[j]
if __name__=="__main__":
li = [54,26,93,17,77,31,44,55,20]
print(li)
select_sort(li)
print(li)
冒泡排序:
#bubble_sort
def bubble_sort(alist):
n = len(alist)
for j in range(0,n-1):
for i in range(0,n-1-j):
if alist[i] > alist[i+1]:
alist[i],alist[i+1] = alist[i+1],alist[i]
if __name__=="__main__":
li = [23,45,1,34,65]
print(li)
bubble_sort(li)
print(li)