php 数组二分法查找函数

 找到返回对应的key,找不到返回-1,注意二分查找需要数组有序,下边函数需要数组递增排序。

function binarySearch($arr,$x){
    $start=0;
    $end=count($arr)-1;
    while($start<=$end){
        $mid=intval(($start+$end)/2);//这里只需要保证中间项下标的计算值为整数即可,也可以四舍五入,不影响结果
        if($arr[$mid]>$x){//如果中间项的值大于待查值,说明代差值位于中间项的左边,因此,起始下标不变,结束下标变成中间项下标减1,第一次搜索的是$arr[0]-$arr[5]的话,下一次搜索
            $end=$mid-1;//$arr[0]-$arr[1]
        }elseif($arr[$mid]<$x){//如果中间项的值小于待查值,说明代差值位于中间项的右边,因此,结束下标不变,起始下标变成中间项下标加1,第一次搜索的是$arr[0]-$arr[5]的话,下一//次搜索是,$arr[3]-$arr[5]
            $start=$mid+1;
        }else{//找到了,返回待查值下标
            return $mid;
        }
    }

    return -1;
}

 

posted @ 2014-04-05 12:20  leezhxing  阅读(1074)  评论(0编辑  收藏  举报