折半插入排序——考研算法

一.基本原理

1.核心思想: 折半插入排序在寻找插入位置时,不是逐个比较而是利用折半查找的原理寻找插入位置 。待排序元素越多,改进效果越明显。
2.算法分析:

设数组为a[0…n]。

  1. 将原序列分成有序区和无序区。a[0…i-1]为有序区,a[i…n] 为无序区。(i从1开始)
  2. 从无序区中取出第一个元素,即a[i],使用二分查找算法在有序区中查找要插入的位置索引j。
  3. 将a[j]到a[i-1]的元素后移,并将a[i]赋值给a[j]。
  4. 重复步骤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, 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值