首頁 >php教程 >PHP开发 >PHP二分查找演算法範例【遞歸與非遞歸方法】

PHP二分查找演算法範例【遞歸與非遞歸方法】

高洛峰
高洛峰原創
2016-12-21 13:51:311211瀏覽

本文實例講述了PHP二分查找演算法。分享給大家供大家參考,具體如下:

binarySearch

二分查找採用的方法比較容易理解,以陣列為例:

① 先取數組中間的值floor((low+top)/2),

② 然後透過與所需查找的數字進行比較,若比中間值大,則將首值替換為中間位置下一個位置,繼續第一步的操作;若比中間值小,則將尾值替換為中間位置上一個位置,繼續第一步操作

③ 重複第二步操作直至找出目標數字

比如從1,3,9,23,54 中查找數字23,

首位置為0, 尾位置為4,中間位置就為2 值為9,比23小,則首位置更新為2+1即3;那麼接下來中間位置就為(3+4)/2=3,值為23,比較相等即找到

//  非递归算法:
//  $target是要查找的目标 $arr是已经排序好的数组
function binary(&$arr,$low,$top,$target){
    while($low <= $top){
//由于php取商是有小数的,所以向下取整,不过也可不加,数组也会取整
      $mid = floor(($low+$top)/2);
      echo $mid."<br>";
      if($arr[$mid]==$target){
        return $arr[$mid];
      }elseif($arr[$mid]<$target){
        $low = $mid+1;
      }else{
        $top = $mid-1;
      }
    }
    return -1;
}

    

//  递归算法:
function binaryRecursive(&$arr,$low,$top,$target){
    if($low<=$top){
      $mid = floor(($low+$top)/2);
      if($mid==$target){
        return $arr[$mid];
      }elseif($arr[$mid]<$target){
        return binaryRecursive($arr,$mid+1,$top,$target);
      }else{
        return binaryRecursive($arr,$low,$top-1,$target);
      }
    }else{
      return -1;
    }
}

   

希望本文所述對大家PHP程式設計有所幫助。

更多PHP二分查找演算法範例【遞歸與非遞歸方法】相關文章請關注PHP中文網!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn