插入排序—一般來說,插入排序都採用 in-place 在數組上實現。具體算法描述如下:
從第一個元素開始,該元素可以認爲已經被排序;
取出下一個元素,在已經排序的元素序列中從後向前掃描;
如果該元素(已排序)大於新元素,將該元素移到下一位置;
重複步驟 3,直到找到已排序的元素小於或者等於新元素的位置;
將新元素插入到該位置後;
重複步驟 2~5。
def insertion_sort(value):
for i in range(len(value)):
for j in range(i+1,len(value)):
if value[i] > value[j]:
value[i],value[j] = value[j],value[i]
return value
#方法二
def insertionSort(arr):
for i in range(len(arr)):
preIndex = i-1
current = arr[i]
while preIndex >= 0 and arr[preIndex] > current:
arr[preIndex+1] = arr[preIndex]
preIndex-=1
arr[preIndex+1] = current
return arr
l = [22,5,19,3,3,6,1,77,55,23,87,45,33]
a = insertion_sort(l)
b = insertionSort(l)
print(a)
print(b)