活动地址:CSDN21天学习挑战赛
✅作者简介:C/C++领域新星创作者,为C++和java奋斗中
✨个人社区:微凉秋意社区
🔥系列专栏:经典算法
📃推荐一款模拟面试、刷题神器👉注册免费刷题
🔥前言
书接上文,今天带来算法基础中的折半插入排序,一个综合了直接插入排序和二分查找的算法。和以往四篇不同,这篇文章将会加入详细调试的图片,帮助大家理解该算法的流程。本篇文章也将收录在经典算法专栏,此专栏免费且收录经典算法,感兴趣的朋友可订阅以便持续观看。
int main(void)
{
int arr[6] = { 27,45,50,35,66,32 };
int len = sizeof(arr) / sizeof(arr[0]);
cout << "排序前:" << endl;
for (int i = 0; i < len; i++) {
cout << arr[i] << " ";
}
cout << endl;
for (int i = 1; i < len ; i++)
{
if (arr[i] < arr[i - 1])
{
int temp = arr[i];
int low = 0;
int high = i - 1;
while (low <= high) {
int middle = (low + high) / 2;
if (temp < arr[middle])
{
high = middle - 1;
}
else
{
low = middle + 1;
}
}
for (int j = i - 1; j >= high + 1; j--)
{
arr[j + 1] = arr[j];
}
arr[high + 1] = temp;
}
}
cout << "排序后:" << endl;
for (int i = 0; i < len; i++) {
cout << arr[i] << " ";
}
}
解析:



i = 3,二分查找结束的条件是 low >high,那么继续逐语句调试,观察数组中元素值的变化
j--,再次调试的话arr[2]的值也会发生改变


i=5时,进入折半排序入口,流程和前五步一致,所以直接看最终调试结果

对于折半插入排序来说,元素的串位次数没有并发生变化,只是在查找位置是更加快速了,因此该算法与直接插入排序处于同一量级。不过在数据量很大时,要优于直接插入排序,时间复杂度仍为O( n 2 n^2 n2)
本文到此结束,如有问题务必交流指正,期待你的关注与支持~