二分查找算法很简单!
要使用二分查找,必须给数组先排序,或者数组已经排好序了。
如果给一个无序的算法排序,如果用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
我不知道这两种实现方法有什么优劣。