91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

PHP中如何判斷一列有序數組是否包含某值

發布時間:2020-08-12 09:31:42 來源:億速云 閱讀:185 作者:小新 欄目:編程語言

小編給大家分享一下PHP中如何判斷一列有序數組是否包含某值,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

問題:對于一列有序數組,如何判斷給出的一個值,該值是否存在于數組。

思路:判斷是否存在,最簡單是,直接循環該數組,對每一個值進行比較。但是對于有序數組來說,這樣寫就完全沒有利用好“有序”這一特點。

所有我們使用到“二分法查找”,

//有序數組為

$arr = array(2,5,66,87,954,1452,5865);

//查找值

$str = 1452;

//我們先定義 三個參數

$front = 0;//一個開始值下標

$end = count($arr) - 1;//一個結束值下標

$mid = intval(($front + $end) / 2);//中間值下標

1、第一次比較,我們直接判斷查找值str是否等于中間值mid,如果等于 直接返回 true;

2、如果查找值str大于中間值mid,則說明查找值str可能在中間值的右邊,即對開始值front需重新賦值 = 中間值mid + 1,結束值end不用變,依次中間值mid為新的開始值 + 結束值;

3、如果查找值str小于中間值mid,則說明查找值str可能在中間值的左邊,即開始值不用變,結束值end需重新賦值 = 中間值 - 1,依次中間值mid為開始值 + 新的結束值;

-----如上,對于傳入的開始值,結束值,中間值,進行比較。一旦開始值 大于 結束值 則說明沒有找到,結束查詢,反之等于就返回已找到。

具體代碼如下:

$str = 89;//查找值

$arr = [1,55,66,89,420];//有序數組

$ren = find($arr, $str);

echo '<pre>';

var_dump($ren);

function find($arr, $str){

 $front = 0;//開始下標

 $end = count($arr) - 1;//結束下標

 while($front <= $end){//結束值 大于 開始值 ,反之則退出

  $mid = intval(($front + $end) / 2);//中間值下標

  if($str == $arr[$mid]){

   return $mid;//存在直接返回值的下標

  }

  if($str > $arr[$mid]){

   $front = $mid + 1;//在前面

  }

  if($str < $arr[$mid]){

   $end = $mid - 1;//在后面

  }

 }

 return false;

}

返回結果:89為第四個元素值下標3

int(3)

看完了這篇文章,相信你對PHP中如何判斷一列有序數組是否包含某值有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

陇南市| 长顺县| 攀枝花市| 孟连| 双鸭山市| 灵台县| 当阳市| 曲水县| 太仆寺旗| 古丈县| 浦北县| 遂溪县| 平邑县| 枞阳县| 名山县| 珲春市| 伊金霍洛旗| 大邑县| 涟水县| 大悟县| 云龙县| 长治县| 闽清县| 涟源市| 大冶市| 梅州市| 方城县| 台山市| 万年县| 临颍县| 营口市| 依兰县| 阿合奇县| 建水县| 哈密市| 富源县| 双柏县| 清新县| 五常市| 云南省| 秦皇岛市|