微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP实现递归有几种方法呢?

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

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

一、利用引用做参数

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

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

functionrecursion(&$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 在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。

functionrecursion($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]

三、利用静态变量

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

functionrecursion($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自学中心

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐