线性查找与二分查找的平均查找次数的比较

*不讨论查找不成功的情况

*设一数组arr,长度为n(下列例子中,n 取具体值 100, 10000, 10000000)

线性查找(顺序查找)

在无序的数组中查找一指定值,必须遍历整个数组,直至查找成功,计算其平均查找次数也相当简单:

avg线性 = (1 + n) / 2

因在数组中,各个元素被查找的概率相等,最好的情况是第1个就是目标元素;最坏的情况是最后一个才是目标元素,就不得不遍历整个数组,平均查找次数是线性递增的:

n = 100,avg线性 = 50.5

n = 10000,avg线性 = 5000.5

n = 10000000,avg线性 = 5000000.5

二分查找

使用二分查找前,必须先保证数组有序,其每次先把目标元素与位于数组中间的值进行比较(假设数组升序),若目标元素较大(小),则舍弃位于数组中间的左(右)边部分,不再比较左(右)边,再使用二分查找比较剩余部分:

直至查找成功后停止。

二分查找的平均查找次数略微复杂:

avg二分 =  ((n+1)*ceil(log2(n+1)) - 2^ceil(log2(n+1)) + 1)/n,

分子是全部元素的查找次数总和,分母就是数组大小n,相除即平均查找次数

???,怎么来的?

数组个数次数总和
11
23(1+2)
35(1+2+2)
48(1+2+2+3)
511(1+2+2+3+3)

6

14(1+2+2+3+3+3)

717(1+2+2+3+3+3+3)
821(1+2+2+3+3+3+3+4)
925(1+2+2+3+3+3+3+4+4)
......

序列1, 3, 5, 8, 11, 14, 17, 21, 25, ... 可在 OEIS 官网 查询得到

二分查找平均查找次数呈对数增长(保留两位小数):

n = 100,avg二分 = 5.8

n = 10000,avg二分 = 12.36

n = 10000000,avg二分 = 22.32

以下给出部分数组大小(图中n列)与平均查找次数(图中approximation列)

(图片数据来源WolframAlpha

二者平均查找次数图形比较

蓝:线性查找

红:二分查找

  • 8
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值