介绍
步骤
动画演示
def bubble_sort(alist):
for i in range(len(alist)-1,0,-1):
for j in range(i):
if alist[j]>alist[j+1]:
alist[j],alist[j+1]=alist[j+1],alist[j]
优化
介绍
步骤
动画演示
python代码实现如下:
def select_sort(alist):
for i in range(len(alist)-1):
min_index=i
for j in range(i+1,len(alist)):
if alist[j]<alist[min_index]:
min_index=j
if min_index!=i:
alist[i],alist[min_index] = alist[min_index],alsit[i]
介绍
步骤
动画演示
python代码实现如下:
def insert_sort(alist):
for i in range(1,len(alsit)):
for j in range(i,0,-1):
if alist[j]<alist[j-1]:
alist[j-1],alist[j]=alist[j],alist[j-1]
介绍
步骤
动画演示
python代码实现如下:
def quick_sort(alist,start,end):
if start>=end:
return
pivot= alist[start]
low = start
high = end
while low < high:
while low < high and pivot < alist[high]:
high-=1
alist[low] = alist[high]
while low < high and alist[low] < pivot:
low+=1
alist[high] = alist[low]
alsit[low] = pivot
quick_sort(alist,start,low-1)
quick_sort(alist,low+1,end)
介绍
步骤
def shell_sort(alist):
gap=len(alist)//2
while gap>0:
for i in range(gap,len(alist)):
j=i
while (j-gap)>=0 and alist[j-gap]>alist[j]:
alist[j-gap],alsit[j]=alist[j],alist[j-gap]
j-=gap
gap//=2
介绍
步骤
动画演示
python代码实现如下:
def merge_sort(alist):
if len(alist)<=1:
return alist
mid = len(alist)//2
left=merge_sort(alsit[:mid])
right=merge_sort(alist[mid:])
return sort(left,right)
def sort(left,right):
l,r=0,0
result=[]
while l<len(left) and r<len(right):
if left[l]<=right[r]:
result.append(left[l])
l+=1
else:
result.append(right[r])
r+=1
result+=left[l:]
result+=right[r:]
return result
介绍
步骤
动画演示
python代码实现如下:
def heap_sort(alist):
n = len(alist)
first = int(n/2-1)
for start in range(first,-1,-1):
max_heapify(alist,start,n-1)
for end in range(n-1,0,-1):
alist[end],alist[0]=alist[0],alist[end]
max_heapify(alist,0,end-1)
return alsit
def max_heapify(alist,start,end):
root = start
while True:
child = root*2+1
if child>end :
break
if child+1<=end and alist[child]<alist[child+1]:
child+=1
if alist[root]<alist[child]:
alist[root],alist[child]=alist[child],alist[root]
root=child
else:
break
参考链接:
https://mp.weixin.qq.com/s/JBwQN9zJbl-PB4ZkBWxWlQ
https://mp.weixin.qq.com/s/pN4RH4pPKtSkZJgcf2V-Vw
https://mp.weixin.qq.com/s/Q24-uujyqgD5JlE4cq49KA
https://mp.weixin.qq.com/s/BBIdFx0rvIkgIeNqU_CZVA