久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP二分查找算法的實現方法示例

這篇文章主要介紹了PHP二分查找算法的實現方法,簡單分析了二分查找算法的原理,并結合具體實例形式給出了php基于循環與遞歸兩種方法實現二分查找的相關操作技巧,需要的朋友可以參

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

二分查找法需要數組是一個有序的數組

假設我們的數組是一個遞增的數組,首先我們需要找到數組的中間位置.

1. 要知道中間位置就需要知道起始位置和結束位置,然后取出中間位置的值來和我們的值做對比。

2. 如果中間值大于我們的給定值,說明我們的值在中間位置之前,此時需要再次二分,因為在中間之前,所以我們需要變的值是結束位置的值,此時結束位置的值應該是我們此時的中間位置。

3. 反之,如果中間值小于我們給定的值,那么說明給定值在中間位置之后,此時需要再次將后一部分的值進行二分,因為在中間值之后,所以我們需要改變的值是開始位置的值,此時開始位置的值應該是我們此時的中間位置,直到我們找到指定值。

4. 或者中間值等于最初的起始位置,或結束位置(此時說明給定值未找到),下面我們來用代碼實現~

//循環實現
function getValue($num,$arr)
{
  //查找數組的中間位置
  $length=count($arr);
  $start=0;
  $end=$length;
  $middle=floor(($start+$end)/2);
  //循環判斷
  while($start>$end-1)
  {
    if($arr[middle]==$num)
    {
      return middle+1;
    } elseif($arr[middle]<$num)
    {
      //如果當前要查找的值比當前數組的中間值還要打,那么意味著該值在數組的后半段
      //所以起始位置變成當前的middle的值,end位置不變。
      $start=$middle;
      $middle=floor(($start+$end)/2);
    } else{
      //反之
      $end=$middle;
      $middle=floor(($start+$end)/2);
    }
  }
  return false;
}

//遞歸實現
/*
* 從數組中獲取元素值
* @param1 int $num,要查找的目標值
* @param2 array $arr,要查找的數組
* @param3 int $start,查找的起始位置
* @param4 int $end,查找的結束位置
* @return mixed,找到了返回位置,沒找到返回false
*/
function getValue4($num,$arr,$start = 0,$end = 100){
    //采用二分法查找
    $middle = floor(($end + $start) / 2);
    //判斷
    if($arr[$middle] == $num){
      //已經找到了,遞歸的出口
      return $middle + 1;
    }elseif($arr[$middle] < $num){
      //要查找的元素在數組的后半段
      $start = $middle + 1;
      //邊界值
      if($start >= $end){
        //沒有找到,但是已經超出邊界值,遞歸出口
        return false;
      }
      //調用自己去查找:遞歸點
      return getValue4($num,$arr,$start,$end);  //getValue4($num,$arr,51,100)
    }else{
      //要查找的元素在數組的前半段
      $end = $middle - 1;
      //判斷邊界值
      if($end < 0)return false;
      //調用自己:遞歸點
      return getValue4($num,$arr,$start,$end);  //getValue4($num,$arr,0,49)
    }
    //都沒有找到
    return false;
}

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》及《php查找技巧與方法總結》

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

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了PHP定義字符串的四種方式,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
下面小編就為大家分享一篇php 替換文章中的圖片路徑,下載圖片到本地服務器的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP給源代碼加密的幾種方法匯總(推薦),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇php打開本地exe程序,js打開本地exe應用程序,并傳遞相關參數方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP類的反射來實現依賴注入過程以及相關知識點分享,對此有興趣的朋友跟著小編學習下吧。
php遍歷一個文件夾內的所有文件和文件夾,并刪除所有文件夾和子文件夾下的所有文件的代碼,通過遞歸方式實現達到清空一個目錄的效果。本文給大家分享實例代碼,需要的朋友參考
主站蜘蛛池模板: 国产视频中文字幕在线观看 | 国产免费人成xvideos视频 | 美国十次成人欧美色导视频 | 欧美成人h版在线观看 | 最近日韩中文字幕 | 中文av网站 | 欧美一级做性受免费大片免费 | 欧美色综合| 91精品国产乱码久久久久久久 | 国产日韩一区二区三免费 | 中文字幕一区二区三区四区五区 | 99视频入口 | 久久久成人精品 | 91久操网| 国产视频在线一区二区 | 国产精品免费高清 | 国产高清免费视频 | 国产天天操 | 精品日韩一区二区 | 蜜桃传媒一区二区 | 一级片免费在线观看 | 午夜免费观看体验区 | 男女啪啪网址 | 99精品久久 | 久久三级影院 | 免费中文字幕 | 视频一区在线观看 | 亚洲精品久久久久久久不卡四虎 | h在线看 | 久久久123| 国产偷录叫床高潮录音 | 九色视频网站 | 一区二区精品电影 | 国产福利免费视频 | 亚洲精品乱码久久久久久久久久 | 久久久片 | 午夜影院网站 | 日韩一二区 | 一区二区视频在线 | 国产一区二区日韩 | 国产成人99久久亚洲综合精品 |