《PHP實例:PHP二分查找算法示例【遞歸與非遞歸方法】》要點:
本文介紹了PHP實例:PHP二分查找算法示例【遞歸與非遞歸方法】,希望對您有用。如果有疑問,可以聯系我們。
PHP教程本文實例講述了PHP二分查找算法.分享給大家供大家參考,具體如下:
PHP教程binarySearch
PHP教程二分查找采用的方法比較容易理解,以數組為例:
PHP教程① 先取數組中間的值floor((low+top)/2),
PHP教程② 然后通過與所需查找的數字進行比較,若比中間值大,則將首值替換為中間位置下一個位置,繼續第一步的操作;若比中間值小,則將尾值替換為中間位置上一個位置,繼續第一步操作
PHP教程③ 重復第二步操作直至找出目標數字
PHP教程比如從1,3,9,23,54 中查找數字23,
PHP教程首位置為0, 尾位置為4,中間位置就為2 值為9,比23小,則首位置更新為2+1即3;那么接下來中間位置就為(3+4)/2=3,值為23,比較相等即找到
PHP教程
// 非遞歸算法:
// $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;
}
PHP教程
// 遞歸算法:
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查找技巧與方法總結》、《PHP數據結構與算法教程》、《php程序設計算法總結》、《php加密方法總結》、《PHP編碼與轉碼操作技巧匯總》、《php面向對象程序設計入門教程》、《PHP數學運算技巧總結》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php正則表達式用法總結》、及《php常見數據庫操作技巧匯總》
PHP教程希望本文所述對大家PHP程序設計有所幫助.
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/3174.html