python之插入排序

插入排序的基本操做就是将一个数据插入到已经排好序的有序数据中,从而获得一个新的、个数加一的有序数据,算法适用于少许数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分红两部分:第一部分包含了这个数组的全部元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。
#encoding=utf-8
def insertSort(listx):
count=len(listx)
for i in range(1,count):#第一个元素自己有序,从第二个开始
key=listx[i]
j=i-1#当前元素前面一个元素
while j>=0:
if listx[j]>key:
listx[j],listx[j+1]=listx[j+1],listx[j]
j-=1#交换完位置以后再次比较
else:
break
return listx算法

if __name__=="__main__":
print (insertSort([3,1,6,7,45,21]))数组

时间复杂度:
最好状况:O(n)
最坏状况:O(n^2)排序

相关文章
相关标签/搜索