用php实现二分查找算法,PHP实现二分查找算法(折半算法)

/**

* 比较函数

* @param scalar $var1

* @param scalar $var2

* return bool

*/

function compare($var1,$var2)

{

if($var1>$var2)

{

return 1;

}

elseif($var1==$var2)

{

return 0;

}

else

{

return -1;

}

}

/**

* 二分查找 重构的代码 支持关联数组

* return index 查找目标数字所在的索引

*/

function binsearch_2($var=array(),$searchnum,$type=true)

{

reset($var);

$key=key($var);

while($key!==null) //$key可能为0 所以要用!==null判断

{

$_map[]=$key; //键值映射

next($var);

$key=key($var);

}

echo '

';

print_r($_map);

$left_border = 0;

$right_border = count($_map)-1;

while($left_border<=$right_border)

{

$middle=intval(($left_border+$right_border)/2);

switch(compare($var[$_map[$middle]],$searchnum))

{

case -1:

if($type)

{

$left_border = $middle+1;

}

else

{

$right_border = $middle-1;

}

break;

case 0:

return $_map[$middle];

case 1:

if($type)

{

$right_border = $middle-1;

}

else

{

$left_border = $middle+1;

}

break;

}

}

echo '没有匹配项';

return false;

}

$arr=array('a'=>1,2,3,4,5,6,7,'b'=>8,9,10,11,'c'=>12);

$index = binsearch_2($arr,12,true);

echo $index;

echo $arr[$index];

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值