PHP數組中什麼是查找演算法?如何找到?

慕斯
發布: 2023-03-10 20:10:01
原創
1613 人瀏覽過

php中找演算法有很多種,你知道的有哪幾種呢?對於查找演算法的含義你又是如何理解的?本篇文章就是帶你去探索關於演算法的一些奧秘,一起探討數組中什麼是尋找演算法?如何找到?

相關推薦:在PHP中什麼是門面模式?他的優點是什麼?適用場景是什麼?

查找演算法:

找出演算法意義:

#尋找是在大量的資訊中尋找- -個特定的資訊元素,在電腦應用中,尋找是常用的基本運算。

查找演算法是指實作查找過程對應的程式碼結。就是中大型數組中去快速定位想要的元素。 。

順序查找演算法:

順序查找也稱為研查找,從資料結構線形表的-端開始,順序掃描,依序將掃描到的結點關鍵字與給定值k比較,若相等則表示查找成功;若掃描結束仍沒有找到關鍵字等於k的結點,表示查找失敗。

我們以程式碼為例:

<?php
//查找算法
//顺序查找
$arr = array(1,3,6,8,23,68,100);
//顺序查找:从数组第一个元素开始,挨个匹配
function check_order($arr , $num){
//全部匹配
for($i = 0,$len = count($arr);$i <$len;$i++){
//判断
if($arr[$i] == $num){
return $i;
}
}
return false ;
}
var_dump(check_order($arr,5));
登入後複製

PHP數組中什麼是查找演算法?如何找到?

#二分找出演算法

二分找出要求線形表中的結點依關鍵字值升序或降序扣列,用始定值k先與中間結點的關鍵字比較,中間結點把線形表分成兩​​個子表,若相等則查找成功;若不相等,再根據k與該中間結點關鍵字的比較結果確定下一步查找哪個子表,這樣遞歸進行,直到查找到或查找結束發現表中沒有這樣的結點。

折半演算法思路:

1、計算陣列長度; 。

2、確定左右兩邊的指標位置; 。

3、找到中間位置;

4、匹配。

5、然後根據大小重定邊界。

<?php
//查找算法
//顺序查找
$arr = array(1,3,6,8,23,68,100);
//顺序查找:从数组第一个元素开始,挨个匹配
function check_order($arr , $num){
//全部匹配
for($i = 0,$len = count($arr);$i <$len;$i++){
//判断
if($arr[$i] == $num){
return $i;
}
}
return false ;
}
//var_dump(check_order($arr,5));
//二分查找算法
//1、 得到数组边界
$right = count($arr);
$left= 0;
$res = 3;
//2、循环匹配,
while($left <=$right){
//3、得到中间位置
$middle = floor(($right + $left) / 2);
//4、匹配数据.
if($arr[$middle] == $res){
  echo $middle;
break;
}
//5、没有找到
if($arr[$middle] < $res){
//值在右边
$left = $middle + 1;
}else{
  //值在左边
  $right = $middle - 1;
登入後複製

PHP數組中什麼是查找演算法?如何找到?

推薦學習:《PHP影片教學

以上是PHP數組中什麼是查找演算法?如何找到?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!