【Python排序算法系列】—— 插入排序

 

21dd41dce63a4f2da07b9d879ad0120b.png

🌈个人主页: Aileen_0v0
🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法
💫个人格言:"没有罗马,那就自己创造罗马~"

2023年度总结→ http://t.csdnimg.cn/yIeru


目录

插入排序

理解

过程演示: 

插入排序实现代码: 

SelfCheck

我的思路:

📝总结:


插入排序

理解

插入排序时间复杂度仍然是O(n²),但算法思路与冒泡排序、选择排序不同
插入排序维持一个已排好序的子列表,其位置始终在列表的前部,然后逐步扩大这个子列表直到全表 —— 跟打扑克牌时,给排好序的扑克牌插入一张牌一样。

看上面的图片,让我联想到贪吃蛇,每次吃一个豆子(元素)让后将其插入到应当插入的位置。

过程演示: 

将第一待排序序列第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列。

从头到尾依次扫描未排序序列,将扫描到的每个元素插入有序序列的适当位置。(如果待插入的元素与有序序列中的某个元素相等,则将待插入元素插入到相等元素的后面。)

插入排序的比对主要用来寻找“新项”的插入位置
最差情况是每趟都与子列表中所有项进行比对,总比对次数与冒泡排序相同,数量级仍是O(n²)
最好情况,列表已经排好序的时候,每趟仅需1次比对,总次数是O(n)


插入排序实现代码: 

def insertionSort(alist):
    for i in range(0,len(alist)):#循环插入的次数
        current = alist[i]#当前要插入的元素值
        preIndex = i - 1 #当前位置 减去 1
        while preIndex >= 0 and alist[preIndex] > current: #前一个位置数值比当前位置数值大
            alist[preIndex + 1] = alist[preIndex] #后一个元素的值等于前一个元素的值,相当于整体后移一位
            preIndex -= 1 #前一个位置始终前移一
        alist[preIndex + 1] = current #把当前元素插入比他小的后一个位置

    return alist

list = [7,6,4,0,9,2,5]
print(insertionSort(list))

SelfCheck

Suppose you have the following list of numbers to sort: [15 , 5 , 4 , 18 , 12 , 19 , 14 , 10 , 8 , 20]  which
list represents the partially sorted list after three complete passes of insertionsort ?

我的思路:

题目说他是插入排序,我就会联想到贪吃蛇,一个一个的吃,并且吃了的元素按顺序排列,那么前三次吃的是15,5,4 ——> 按顺序排列就是 4,5,15;后面元素位置不变,所以选择第三个。


📝总结:

 

  • 27
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 16
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aileen_0v0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值