时间:2021-05-26
递归函数是我们常用到的一类函数,最基本的特点是函数自身调用自身,但必须在调用自身前有条件判断,否则会无限调用下去。
一般来说,递归函数可利用全局变量,引用,静态变量,但需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好的技巧。
一、利用引用做参数
PHP 的引用允许用两个变量来指向同一个内容,例如 $a = &$b; 这意味着 $a 和 $b 指向了同一个变量。
如下例子,因为 $data 使用了引用传递,所以数据会一直累加。
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 在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。
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]三、利用静态变量
静态变量只在第一次调用时初始化。仅在局部函数域中存在,但当程序执行离开此作用域时,其值并不丢失。
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 递归的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
java实现多线程的三种方法在java中,有三种方法可以实现多线程。第一种方法:继承Thread类,重写run函数。第二种方法:实现Runnable接口,重写r
本文实例讲述了php实现将数组或对象写入到文件的方法。分享给大家供大家参考,具体如下:php将数组或对象原样写入或保存到文件有三种方法可以实现第一种方法是使用s
php读取文件内容的三种方法://**************第一种读取方式*****************************复制代码代码如下:head
本文实例总结了php实现四舍五入的方法。分享给大家供大家参考。具体分析如下:php实现四舍五入的三种方法,分别通过number_format函数、round函数
一、使用三种方法实现0-n累加求和定义函数分别使用while循环、for循环、递归函数实现对0-n的累加求和1、使用while循环定义一个累加求和函数sum1(