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

文章目录

插入排序

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

对链表进行插入排序

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

比对次数没变

小结

相关推荐
林的快手7 分钟前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode
千天夜16 分钟前
多源多点路径规划:基于启发式动态生成树算法的实现
算法·机器学习·动态规划
从以前21 分钟前
准备考试:解决大学入学考试问题
数据结构·python·算法
.Vcoistnt44 分钟前
Codeforces Round 994 (Div. 2)(A-D)
数据结构·c++·算法·贪心算法·动态规划
ALISHENGYA1 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战训练三)
数据结构·c++·算法·图论
我码玄黄3 小时前
正则表达式优化之算法和效率优化
前端·javascript·算法·正则表达式
Solitudefire4 小时前
蓝桥杯刷题——day9
算法·蓝桥杯
三万棵雪松5 小时前
1.系统学习-线性回归
算法·机器学习·回归·线性回归·监督学习
Easy数模5 小时前
基于LR/GNB/SVM/KNN/DT算法的鸢尾花分类和K-Means算法的聚类分析
算法·机器学习·支持向量机·分类·聚类
2401_858286115 小时前
117.【C语言】数据结构之排序(选择排序)
c语言·开发语言·数据结构·笔记·算法·排序算法