首頁 >後端開發 >php教程 >php 使用遞歸演算法無限遍歷數組範例程式碼

php 使用遞歸演算法無限遍歷數組範例程式碼

怪我咯
怪我咯原創
2017-07-12 11:41:391988瀏覽

遞迴演算法是把問題轉換成規模縮小了的同類問題的子問題。然後遞歸呼叫函數(或過程)來表示問題的解。

一個過程(或函數)直接或間接呼叫自己本身,這種過程(或函數)叫遞歸過程(或函數).

這篇文章主要介紹了PHP使用遞歸演算法無限遍歷數組,結合實例形式分析了php針對一維數組二維數組及多維不規則數組的通用遍歷技巧,需要的朋友可以參考下具體如下:

<?php
//无限遍历数组
$a1 = array("a", "b", "c"); //一维数组
$a2 = array(array(21, 3, 6), array("a", "b", "c")); //二维数组
$a3 = array(array(array(5, 55), 4, 444), 2, 7, 6, 8, array("w", "d", array(3, 2, "a"), "s")); //多维不规则数组
function fun($a) {
  foreach ($a as $val) {
    if (is_array($val)) { //如果键值是数组,则进行函数递归调用
      fun($val);
    } else { // 如果键值是数值,则进行输出
      echo "$val<br />";
    } //end if
    
  } //end foreach
  
} //end fun
//fun($a1);
//fun($a2);
fun($a3);
?>

輸出:

5
55
4
444
2
7
6
8
w
d
3
2
a
s

以上是php 使用遞歸演算法無限遍歷數組範例程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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