码迷,mamicode.com
首页 > 其他好文 > 详细

二分查找法

时间:2017-04-29 21:00:25      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:binary   print   function   sort   bnu   查找   amp   else   count   

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

二分查找法

标签:binary   print   function   sort   bnu   查找   amp   else   count   

原文地址:http://www.cnblogs.com/yulei126/p/6786164.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!