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

文章目录

插入排序

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

对链表进行插入排序

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

比对次数没变

小结

相关推荐
起名字真南13 分钟前
【C++】深入理解自定义 list 容器中的 list_iterator:迭代器实现详解
数据结构·c++·windows·list
不去幼儿园19 分钟前
【SSL-RL】自监督强化学习: 好奇心驱动探索 (CDE)算法
大数据·人工智能·python·算法·机器学习·强化学习
YYDS31421 分钟前
C++各类函数评点+详解
开发语言·数据结构·c++·算法·贪心算法·动态规划
SaNDJie23 分钟前
24.11.13 机器学习 特征降维(主成份分析) KNN算法 交叉验证(K-Fold) 超参数搜索
人工智能·算法·机器学习
薯条不要番茄酱1 小时前
数据结构-5.二叉树
java·开发语言·数据结构
cleverpeople2 小时前
11.15作业
c语言·开发语言·算法
Seeklike2 小时前
11.14 机器学习-朴素贝叶斯+决策树算法
算法·决策树·机器学习
徐浪老师4 小时前
深入解析贪心算法及其应用实例
算法·贪心算法
软行4 小时前
LeetCode 单调栈 下一个更大元素 I
c语言·数据结构·算法·leetcode
钰爱&5 小时前
【操作系统】Linux之线程同步二(头歌作业)
linux·运维·算法