PHP資料結構(1) 二分尋找

來源:互聯網
上載者:User
二分尋找的基本思路是將一個有序數組取中間的那個值和所尋找的值進行大小比較,當所尋找的值大於數組的中間值時,即說明該有序數組中間值前的所有值都小於該尋找的值,所以可以將該數組中間值前的所有值排除,再從該數組中間值到該數組末尾的值中繼續尋找所需值,其代碼實現如下:

//二分尋找
function bin_search($array,$search){
$low=0;
$height=count($array)-1;//擷取數組長度

while($low<=$height){
$mid=floor(($low+$height)/2);//擷取中間數,強制轉換為floor類型,防止出錯
if($array[$mid]==$search){
return $mid+1;//返回已找到的序號
}else if($array[$mid]<$search){
//當中間值小於所查值時,則$mid左邊的值都小於$search,此時要將$mid賦值給$low
$low=$mid+1;
}else if($array[$mid]>$search){
//此時說明中間值大於所查值,則$mid右邊的所有值都大於$search,此時要將$mid賦值給$height
$height=$mid-1;
}
return "尋找失敗";//尋找失敗,數組中不存在該值

}

}
$arr=array(1,4,6,33,75,88,89,93);
echo bin_search($arr,33);
echo bin_search($arr,66);
?>

以上就介紹了PHP資料結構(1) 二分尋找,包括了方面的內容,希望對PHP教程有興趣的朋友有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.