您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)PHP中如何實(shí)現(xiàn)一個(gè)二分查找算法,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
binarySearch
二分查找采用的方法比較容易理解,以數(shù)組為例:
① 先取數(shù)組中間的值floor((low+top)/2),
② 然后通過(guò)與所需查找的數(shù)字進(jìn)行比較,若比中間值大,則將首值替換為中間位置下一個(gè)位置,繼續(xù)第一步的操作;若比中間值小,則將尾值替換為中間位置上一個(gè)位置,繼續(xù)第一步操作
③ 重復(fù)第二步操作直至找出目標(biāo)數(shù)字
比如從1,3,9,23,54 中查找數(shù)字23,
首位置為0, 尾位置為4,中間位置就為2 值為9,比23小,則首位置更新為2+1即3;那么接下來(lái)中間位置就為(3+4)/2=3,值為23,比較相等即找到
// 非遞歸算法: // $target是要查找的目標(biāo) $arr是已經(jīng)排序好的數(shù)組 function binary(&$arr,$low,$top,$target){ while($low <= $top){ //由于php取商是有小數(shù)的,所以向下取整,不過(guò)也可不加,數(shù)組也會(huì)取整 $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中如何實(shí)現(xiàn)一個(gè)二分查找算法,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。