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 class="brush:php;toolbar:false">'; 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
推薦影片教學:《php教學》
以上是PHP查找一列有序數組是否包含某值(二分查找)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

CakePHP 是 PHP 的開源框架。它旨在使應用程式的開發、部署和維護變得更加容易。 CakePHP 基於類似 MVC 的架構,功能強大且易於掌握。模型、視圖和控制器 gu

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

CakePHP 是一個開源MVC 框架。它使應用程式的開發、部署和維護變得更加容易。 CakePHP 有許多函式庫可以減少大多數常見任務的過載。

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲
