首頁 後端開發 php教程 當涉及到遞歸時,如何找到多維數組中第一個匹配鍵的值?

當涉及到遞歸時,如何找到多維數組中第一個匹配鍵的值?

Oct 30, 2024 am 11:43 AM

How can I find the value of the first matching key in a multidimensional array when recursion is involved?

檢索多維數組中第一個匹配鍵的值:解決遞歸問題

在軟體開發中,導航多維數組並搜尋特定鍵是一項常見任務。然而,當涉及遞歸時,事情就會變得棘手。讓我們剖析以下程式碼片段,該程式碼片段旨在查找與匹配鍵關聯的值:

<code class="php">private function find($needle, $haystack) {
    foreach ($haystack as $name =&gt; $file) {
        if ($needle == $name) {
            return $file;
        } else if(is_array($file)) { //is folder
            return $this-&gt;find($needle, $file); //file is the new haystack
        }               
    }
    
    return "did not find";
}</code>
登入後複製

問題在於遞歸本身。當遇到乾草堆中的陣列時,檔案變數將成為新的乾草堆。但是,對原始乾草堆的引用丟失,可能會導致永恆的遞歸循環。

要解決這個問題,請考慮以下解決方案:

RecursiveIteratorIterator

PHP 5.6 及更高版本引入了RecursiveIteratorIterator,它大大簡化了任務:

<code class="php">function recursiveFind(array $haystack, $needle)
{
    $iterator  = new RecursiveArrayIterator($haystack);
    $recursive = new RecursiveIteratorIterator(
        $iterator,
        RecursiveIteratorIterator::SELF_FIRST
    );
    foreach ($recursive as $key =&gt; $value) {
        if ($key === $needle) {
            return $value;
        }
    }
}</code>
登入後複製

這種方法利用了遍歷數組的RecursiveArrayIterator 和有效迭代所有元素(包括嵌套數組)的RecursiveIteratorIterator。

基於生成器的函數

對於PHP 5.6 及更高版本,您可以使用生成器來擷取所有符合的值:

<code class="php">function recursiveFind(array $haystack, $needle)
{
    $iterator  = new RecursiveArrayIterator($haystack);
    $recursive = new RecursiveIteratorIterator(
        $iterator,
        RecursiveIteratorIterator::SELF_FIRST
    );
    foreach ($recursive as $key =&gt; $value) {
        if ($key === $needle) {
            yield $value;
        }
    }
}</code>
登入後複製

此函數傳回使用yield關鍵字匹配值,允許您使用foreach循環遍歷所有值。

以上是當涉及到遞歸時,如何找到多維數組中第一個匹配鍵的值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

11個最佳PHP URL縮短腳本(免費和高級) 11個最佳PHP URL縮短腳本(免費和高級) Mar 03, 2025 am 10:49 AM

11個最佳PHP URL縮短腳本(免費和高級)

Instagram API簡介 Instagram API簡介 Mar 02, 2025 am 09:32 AM

Instagram API簡介

在Laravel中使用Flash會話數據 在Laravel中使用Flash會話數據 Mar 12, 2025 pm 05:08 PM

在Laravel中使用Flash會話數據

簡化的HTTP響應在Laravel測試中模擬了 簡化的HTTP響應在Laravel測試中模擬了 Mar 12, 2025 pm 05:09 PM

簡化的HTTP響應在Laravel測試中模擬了

php中的捲曲:如何在REST API中使用PHP捲曲擴展 php中的捲曲:如何在REST API中使用PHP捲曲擴展 Mar 14, 2025 am 11:42 AM

php中的捲曲:如何在REST API中使用PHP捲曲擴展

構建具有Laravel後端的React應用程序:第2部分,React 構建具有Laravel後端的React應用程序:第2部分,React Mar 04, 2025 am 09:33 AM

構建具有Laravel後端的React應用程序:第2部分,React

在Codecanyon上的12個最佳PHP聊天腳本 在Codecanyon上的12個最佳PHP聊天腳本 Mar 13, 2025 pm 12:08 PM

在Codecanyon上的12個最佳PHP聊天腳本

Laravel中的通知 Laravel中的通知 Mar 04, 2025 am 09:22 AM

Laravel中的通知

See all articles