中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在PHP項目中實現一個二分查找算法

發布時間:2020-12-31 16:06:44 來源:億速云 閱讀:171 作者:Leah 欄目:開發技術

本篇文章給大家分享的是有關如何在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項目中實現一個二分查找算法,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄平县| 泗洪县| 特克斯县| 闻喜县| 凌源市| 贵德县| 鞍山市| 和平县| 永兴县| 井陉县| 雷山县| 贡嘎县| 密云县| 喀什市| 讷河市| 乐昌市| 华蓥市| 民丰县| 巴林右旗| 丹巴县| 泽库县| 宁强县| 克什克腾旗| 广宗县| 远安县| 鲁甸县| 丹棱县| 惠安县| 东平县| 霍林郭勒市| 博兴县| 根河市| 罗定市| 上高县| 封丘县| 诸暨市| 汉中市| 黑龙江省| 黔西县| 开鲁县| 西平县|