九种查找算法-插值查找
创始人
2024-05-20 02:55:14
0

插值查找

 

一、什么是插值查找

(1)插值查找算法类似于二分查找,不同的是插值查找每次从自适应 mid 处开始查找。

(2)二分查找中mid值是left和right所指序列下标的和的1/2即 mid = (left+right)/ 2。

(3)而插值查找的mid 值是通过公式计算得来由,由公式可以明显看出mid的值并非像二分那样为左右索引的中间位置。

(4)插值查找公式;3、int mid = low + (high - low) * (key - arr[low]) / (arr[high] - arr[low]) ;low表示左边索引left,high表示右边索引right. key 就是需要查找的值。

二、插值查找的特点

(1)查找的序列必须有序

(2)对于数据量大的以及关键字分布均匀的有序序列来说,插值查找的速度较快。

(3)对于分布不均匀的有序序列来说,该算法不一定比二分查找要好。

 

插值查找基于二分查找算法,将查找点的选择改进为自适应选择,可以提高查找效率。当然,差值查找也属于有序查找

算法思路

  1. 确定查找范围low=0,high=N-1,计算中项mid=low+(key-a[low])/(a[high]-a[low])*(high-low)。

  2. 若mid==x或low>=high,则结束查找;否则,向下继续。

  3. 若amidx,说明待查找的元素值只可能在比中项元素小的范围内,则把mid-1的值赋给higt,并重新计算mid,转去执行步骤2。

说明

  • 插值查找是基于折半查找进行了优化的查找方法。

  • 当表长较大,而关键字分布又比较均匀的查找表来说,插值查找算法的平均性能要比折半查找要好得多。

代码

#includeint array[10] = { 1, 4, 9, 16, 27, 31, 33, 35, 45, 64 };int InsertionSearch(int data)
{int low = 0;int high = 10 - 1;int mid = -1;int comparisons = 1;int index = -1;while(low <= high){printf("比较 %d 次\n" , comparisons );printf("low : %d, list[%d] = %d\n", low, low, array[low]);printf("high : %d, list[%d] = %d\n", high, high, array[high]);comparisons++;mid = low + (((double)(high - low) / (array[high] - array[low])) * (data - array[low]));printf("mid = %d\n",mid);// 没有找到if(array[mid] == data){index = mid;break;}else{if(array[mid] < data){low = mid + 1;}else{high = mid - 1;}}}printf("比较次数: %d\n", --comparisons);return index;
}int main()
{int location = InsertionSearch(27);  //测试代,查27,可以找到if(location != -1){printf("查找元素顺序为: %d\n" ,(location+1));}else{printf("没有查找到");}return 0;
}

 

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...