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

文章目录

  • 插入排序
  • 算法实现
  • 算法效率分析
  • 优化-折半插入排序
  • 代码实现
  • 对链表进行插入排序
  • 小结

插入排序

数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第1张图片
首先49当作第一个已经排好序得元素,将第二个元素与前面得元素对比,发现小于49,于是49移动位置
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第2张图片
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第3张图片
此时将65与之前元素对比,发现其最大,位置不变
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第4张图片
97同65处理一样
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第5张图片
此时76小于97,97移动位置,然后再与前面元素比对,发现大于,此时不动
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第6张图片
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第7张图片
此时13最小,每次与之前元素比对都是小于,都会移动位置
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第8张图片
此时比对移动直到13才大于
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第9张图片
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第10张图片
49与之前比对,此时大于才移动,等于小于都不移动,这样保证稳定性
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第11张图片

算法实现

此时循环n次,每次将第i个元素与前i-1个元素比对,如果发现元素大于第i个元素就将该元素右移一位
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第12张图片
从一开始存储,0当作哨兵,当作当前第i个元素
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第13张图片

算法效率分析

数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第14张图片
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第15张图片
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第16张图片
最好时间复杂度和最坏时间复杂度之和除2来算平均时间复杂度,一般和最坏时间复杂度一样
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第17张图片

优化-折半插入排序

0位置为前i-1个元素都要比对的元素,55发现大于mid,此时low=mid+1
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第18张图片
此时55小于70,high=mid-1
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第19张图片
此时high mid low都相等
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第20张图片
接着55小于60,low=mid+1,此时low大于high,此时low的元素大于55,而high的元素小于55
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第21张图片
插入60
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第22张图片
此时发现mid=60,为了保证稳定性,此时不会停止数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第23张图片
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第24张图片
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第25张图片
插入90,最终low大于high时
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第26张图片
插入10,最终low大于high时
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第27张图片

代码实现

此时相同也要low=mid+1
high+1=low当最后low大于high时
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第28张图片

对链表进行插入排序

折半查找对于链表无法实现
比对次数没变
数据结构和算法-插入排序(算法效率 折半优化 顺序表与链表插入排序 代码实现)_第29张图片

小结

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

你可能感兴趣的:(王道数据结构和算法考研笔记,数据结构,算法,链表)