二分查找算法

二分查找算法很简单!

要使用二分查找,必须给数组先排序,或者数组已经排好序了。

如果给一个无序的算法排序,如果用qsort,有时不行,因为qsort的最坏时间是n^2时间级别的,该用merge sort会好一些。这是我做算法竞赛题目的经验。

采用左边界,右边界,中间数策略。

如果目标数大于中间数,更新左边界。

如果目标数小于中间数,更新右边界。

如果目标数等于中间数,找到目标。

直至左边界,右边界相等就结束查找。


用c语言实现二分查找的细节:

左右边界的选择有四种策略。

对于a[0] ... a[n-1] 数组来说

左边界等于-1,右边界等于n

左边界等于-1,右边界等于n-1

左边界等于0,右边界等于n

左边界等于0,右边界等于n-1,这里循环的判定条件是左边界<=右边界,因为如果没有相等,0 < 1 时我们无法进入循环,也就无法找到与a[0],a[1]相同的数了。

第四种是我经常使用的!

中间数有两种实现方法:

中间数=(左边界+右边界)/2

中间数=左边数+(右边数-左边数)/2

我不知道这两种实现方法有什么优劣。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值