排序之插入排序

时间复杂度:O(n ** 2)

def insert_sort(li):
    for i in range(len(li)):
        temp = li[i]
        j = i - 1
        while j >= 0 and li[j] > temp:
            li[j + 1] = li[j]
            j -= 1
        li[j + 1] = temp
        print(li)

  思路:可以将整个过程模拟成摸牌,temp表示摸到的牌,摸到temp后将比较temp(前面已经排序的牌),然后找到temp的插入位置,重复len(li)躺即可。

posted @ 2020-05-16 22:35  顽强的allin  阅读(155)  评论(0编辑  收藏  举报