二分查找法

$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);

posted @ 2017-05-18 15:24  张宇航  阅读(129)  评论(0编辑  收藏  举报
友情链接:回力 | 中老年女装 | 武汉英语培训机构 | SAT培训机构 | 托福培训机构