PHP实现递归的三种方法

吾爱主题 阅读:150 2021-10-19 13:16:00 评论:0

递归函数是我们常用到的一类函数,最基本的特点是函数自身调用自身,但必须在调用自身前有条件判断,否则会无限调用下去。

一般来说,递归函数可利用全局变量,引用,静态变量,但需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好的技巧。

一、利用引用做参数

PHP 的引用允许用两个变量来指向同一个内容,例如 $a = &$b; 这意味着 $a 和 $b 指向了同一个变量。

如下例子,因为 $data 使用了引用传递,所以数据会一直累加。

?
1 2 3 4 5 6 7 8 9 10 11 function recursion(& $data = [], $i = 0) {   if ( $i < 10) {    $data [] = $i ;    $i ++;    $this ->recursion( $data , $i );   }   return $data ; } // 调用 $this ->recursion(); // [0,1,2,3,4,5,6,7,8,9]

二、利用全局变量

global 在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。

?
1 2 3 4 5 6 7 8 9 10 11 12 13 function recursion( $data = [], $i = 0) {   global $data ;   if ( $i < 10) {    $data [] = $i ;    $i ++;    $this ->recursion( $data , $i );   }   return $data ; }   // 调用 $this ->recursion(); // [0,1,2,3,4,5,6,7,8,9]

三、利用静态变量

静态变量只在第一次调用时初始化。仅在局部函数域中存在,但当程序执行离开此作用域时,其值并不丢失。

?
1 2 3 4 5 6 7 8 9 10 11 12 13 function recursion( $i = 0) {   static $data = [];   if ( $i < 10) {    $data [] = $i ;    $i ++;    $this ->recursion( $i );   }   return $data ; }   // 调用 $this ->recursion(); // [0,1,2,3,4,5,6,7,8,9]

以上就是PHP实现递归的三种方法的详细内容,更多关于PHP 递归的资料请关注服务器之家其它相关文章!

原文链接:https://www.cnblogs.com/woods1815/archive/2020/07/04/13234610.html

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容