查找

1.顺序查找

$arr = array(1,2,3,4,4);
//顺序查找
function search($value, &$arr)
{
    $arr_search = array();
    foreach ($arr as $k=>$v)
    {
        if($v==$value)
        {
            $arr_search[$k] = $v;
        }
    }
    
    if(empty($arr_search))
    {
        return false;
    }else{
        return $arr_search;
    } 
}

var_dump(search(4,$arr));

 

 2.二分法查找

 

/**
 * 二分查找,前提是该数组必须是个有序的才行,如果不是必须先排序
 
*/
$arr = array(1,2,3,4,5,6);
function binarySearch($value, &$arr$leftIndex$rightIndex)
{
    if($rightIndex<$leftIndex)
    {
        echo '找不到该数';
        exit();
    }
    
    //首先找到中间数,并不一定非得是正中间
    $middleIndex = round(($rightIndex+$leftIndex)/2);
    
    //如果大于则,向后找
    if($value>$arr[$middleIndex]){
        binarySearch($value$arr$middleIndex+1, $rightIndex);
    }elseif($value<$arr[$middleIndex]){
        binarySearch($value$arr$leftIndex$middleIndex-1);
    }else{
        echo '找到了,下标是:'.$middleIndex;
    }
}

print_r(binarySearch(6, $arr, 0, count($arr)-1));

转载于:https://www.cnblogs.com/siqi/archive/2012/09/02/2667391.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值