一.基本原理
1.核心思想: 折半插入排序在寻找插入位置时,不是逐个比较而是利用折半查找的原理寻找插入位置 。待排序元素越多,改进效果越明显。
2.算法分析:
设数组为a[0…n]。
- 将原序列分成有序区和无序区。a[0…i-1]为有序区,a[i…n] 为无序区。(i从1开始)
- 从无序区中取出第一个元素,即a[i],使用二分查找算法在有序区中查找要插入的位置索引j。
- 将a[j]到a[i-1]的元素后移,并将a[i]赋值给a[j]。
- 重复步骤2~3,直到无序区元素为0。
二.图例演示:
如上图所示,以一组数据{15,27,36,53,69} 和42为例,进行折半插入排序的算法演示:
1. 初始化:默认low下标为0,high下标为4,mid=(low+high)/2;
2. 第一次对比:a[mid]=36<42,则low=mid+1;
3. 第二次对比:mid=(3+4)/2=3,a[mid]=53>42;则high=mid-1;
4. 查找结束:此时high<low,跳出循环,原a[mid]后的数后移;
5. 插入:a[mid]=42;
三.代码实现
void BinsertSort(RedType L,


942

被折叠的 条评论
为什么被折叠?



