插入排序

插入排序—一般來說,插入排序都採用 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)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章