数据结构与算法笔记—— 插入排序

Posted 别呀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据结构与算法笔记—— 插入排序相关的知识,希望对你有一定的参考价值。

什么是插入排序

插入排序(英语: Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

算法步骤:
① 将第一排序序列第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列。
② 从头到尾依次扫描未排序序列,将扫描到的每个元素插入有序序列的适当位置。(如果待插入的元素与有序序列中的某个元素相等,则将待插入元素插入到相等元素的后面。)


插入排序的演示


时间复杂度

  • 最优时间复杂度:O(n)(升序排列,序列已经处于升序状态)
  • 最坏时间复杂度:O(n^2)
  • 稳定性:稳定

代码实现

def insert_sort(alist):
    '''插入排序'''
    n = len(alist)
    # 从右边的无序序列中取出多少个元素执行这样的过程
    for j in range(1,n):
        # i 代表内层循环的起始值
        i = j
        while i>0:
            if alist[i] < alist[i-1]:
                alist[i],alist[i-1] = alist[i-1],alist[i]
                i -= 1
            else:
                break

if __name__ == '__main__':
    li = [54,26,93,17,77,31,44,55,20]
    print(li)
    insert_sort(li)
    print(li)

结果:

[54, 26, 93, 17, 77, 31, 44, 55, 20]
[17, 20, 26, 31, 44, 54, 55, 77, 93]

以上是关于数据结构与算法笔记—— 插入排序的主要内容,如果未能解决你的问题,请参考以下文章

数据结构与算法学习笔记排序

python 学习笔记 -- 数据结构与算法 插入排序 Insertion Sort

尚硅谷算法与数据结构学习笔记07 -- 排序算法2

尚硅谷算法与数据结构学习笔记07 -- 排序算法2

《算法》笔记 3 - 选择排序插入排序希尔排序

数据结构学习笔记(八大排序算法)整理与总结