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

文章目录

插入排序

首先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时

对链表进行插入排序

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

比对次数没变

小结

相关推荐
wfbcg2 分钟前
每日算法练习:LeetCode 28. 找出字符串中第一个匹配项的下标 ✅
算法·leetcode·职场和发展
yy55275 分钟前
Mysql 高可用集群
数据结构
海天一色y19 分钟前
格林函数简介
数据结构
阿Y加油吧30 分钟前
力扣滑动窗口两大压轴题:最小覆盖子串 + 滑动窗口最大值(保姆级思路 + 代码详解)
算法·leetcode·职场和发展
北顾笙98039 分钟前
day11-数据结构力扣
数据结构·算法·leetcode
月落归舟1 小时前
Lambda + Arrays---小练习
数据结构·算法
SilentSlot1 小时前
[数据结构]B树的基本定义和操作
数据结构·b树·前端框架
2601_955354461 小时前
seo臻系统和百度seo有什么区别
算法
君义_noip1 小时前
信息学奥赛一本通 1487:【例 2】北极通讯网络
算法·图论·信息学奥赛·csp-s
会编程的土豆1 小时前
【leetcode hot 100】二叉树二叉树
数据结构·算法·leetcode