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)排序

相關文章
相關標籤/搜索