数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)

文章目录

插入排序

首先49当作第一个已经排好序得元素,将第二个元素与前面得元素对比,发现小于49,于是49移动位置

此时将65与之前元素对比,发现其最大,位置不变

97同65处理一样

此时76小于97,97移动位置,然后再与前面元素比对,发现大于,此时不动

此时13最小,每次与之前元素比对都是小于,都会移动位置

此时比对移动直到13才大于

49与之前比对,此时大于才移动,等于小于都不移动,这样保证稳定性

算法实现

此时循环n次,每次将第i个元素与前i-1个元素比对,如果发现元素大于第i个元素就将该元素右移一位

从一开始存储,0当作哨兵,当作当前第i个元素

算法效率分析



最好时间复杂度和最坏时间复杂度之和除2来算平均时间复杂度,一般和最坏时间复杂度一样

优化-折半插入排序

0位置为前i-1个元素都要比对的元素,55发现大于mid,此时low=mid+1

此时55小于70,high=mid-1

此时high mid low都相等

接着55小于60,low=mid+1,此时low大于high,此时low的元素大于55,而high的元素小于55

插入60

此时发现mid=60,为了保证稳定性,此时不会停止

插入90,最终low大于high时

插入10,最终low大于high时

代码实现

此时相同也要low=mid+1

high+1=low当最后low大于high时

对链表进行插入排序

折半查找对于链表无法实现

比对次数没变

小结

相关推荐
NAGNIP4 小时前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP5 小时前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮5 小时前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法
爱理财的程序媛11 小时前
openclaw 盯盘实践
算法
MobotStone14 小时前
Google发布Nano Banana 2:更快更便宜,图片生成能力全面升级
算法
颜酱18 小时前
队列练习系列:从基础到进阶的完整实现
javascript·后端·算法
用户57573033462418 小时前
两数之和:从 JSON 对象到 Map,大厂面试官到底在考察什么?
算法
程序猿追18 小时前
“马”上行动:手把手教你基于灵珠平台打造春节“全能数字管家”
算法
ZPC82101 天前
docker 镜像备份
人工智能·算法·fpga开发·机器人