二分查找法

Posted 余磊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二分查找法相关的知识,希望对你有一定的参考价值。

$arr = array(4,58,11,34,88,45,32,54,63,78);

function binary($arr,$bnum)
{
 if(is_array($arr) && count($arr) > 0)
 {
  sort($arr);
  $start = 0;
  $end = count($arr)-1;
  $mid = -1;
  while($start <= $end)
  {
   $mid = floor( ($start+$end)/2 );
   if($arr[$mid] == $bnum)
   {
    return $arr[$mid];
   }else if($arr[$mid] < $bnum)
   {
    $start = $mid +1;
   }else if($arr[$mid] > $bnum)
   {
    $end = $mid - 1;
   }
  }
  return -1;
 }
}
$mm = binary($arr,32);
print_r($mm);

以上是关于二分查找法的主要内容,如果未能解决你的问题,请参考以下文章

java 二分查找法

二分查找法以及拉格朗日插值查找法

冒泡排序,递归二分查找法,二分查找法

二分查找法 冒泡排序法

二分查找算法

算法篇——二分查找法(折半查找法)