• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php 递归函数的三种实现方式

php 搞代码 3年前 (2022-01-23) 35次浏览 已收录 0个评论

递归函数是我们常用到的一类函数,最基本的特点是函数自身调用自身,但必须在调用自身前有条件判断,否则无限无限调用下去。实现递归函数可以采取什么方式呢?本文列出了三种基本方式。理解其原来需要一定的基础知识水品,包括对全局变量,引用,静态变量的理解,也需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好地技巧。如果对无限级分类感兴趣,请参照php利用递归函数实现无限级分类。我习惯套用通俗的话解释复杂的道理,您确实不明白请参见手册。

  利用引用做参数

  先不管引用做不做参数,必须先明白引用到底是什么?引用不过是指两个不同名的变量指向同一块存储地址。本来每个变量有各自的存储地址,赋值删除各行其道。现在可好,两个变量共享一块存储地址。 $a=&$b; 。实际上指的是 $a 不管不顾自己原来的存储地址,非要和 $b 共享一室了。因而任何对存储地址数值的改变都会影响两个值。  

  函数之间本来也是各行其是,即便是同名函数。递归函数是考虑将引用作为参数,成为一个桥梁,形成两个函数间的数

5本文来源gao!daima.com搞$代!码#网#

搞代gaodaima码

据共享。虽然两个函数见貌似操作的是不同地址,但是实际上操作的是一块儿内存地址。

<span>function</span> test(<span>$a</span>=0,&<span>$result</span>=<span>array</span><span>()){</span><span>$a</span>++<span>;</span><span>if</span> (<span>$a</span><10<span>) {    </span><span>$result</span>[]=<span>$a</span><span>;    test(</span><span>$a</span>,<span>$result</span><span>);}<br />echo $a;</span><span>return</span><span>$result</span><span>;}</span>

  上面的例子非常简答,以$a<10作为判断条件,条件成立,则把$a赋给$result[];将$result的引用传入函数,会将每一次递归产生的$a添加到结果数组$result。因而本例生成的$result数组是 Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 [6] => 7 [7] => 8 [8] => 9 )

本例比较有意思的是echo $a 的值。相信很多人认为是12345678910吧,其实不然,是1098765432。为什么呢?因为函数还没执行echo $a前就进行了下一次的函数递归。真正执行echo $a是当$a<10条件不满足的时候,echo $a,返回$result,对于上一层而言,执行完递归函数,开始执行本层的echo $a,依次类推。

  利用全局变量

  利用全局变量完成递归函数,请确保你确实理解什么是全局变量。global在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。但一旦用了&,同名变量不再是同名引用。利用全局变量实现递归函数没必要理解到这么深的一层,还保持原有对全局变量的看法就可以顺理成章理解递归函数。

<span>function</span> test(<span>$a</span>=0,<span>$result</span>=<span>array</span><span>()){    </span><span>global</span><span>$result</span><span>;    </span><span>$a</span>++<span>;    </span><span>if</span> (<span>$a</span><10<span>) {        </span><span>$result</span>[]=<span>$a</span><span>;        test(</span><span>$a,$result</span><span>);    }    </span><span>return</span><span>$result</span><span>;}</span>

利用静态变量

我们常常在类中见到static,今天我们把它利用到递归函数中。请记住static的作用:仅在第一次调用函数的时候对变量进行初始化,并且保留变量值。

  举个栗子:

<span>function</span><span> test(){</span><span>static</span><span>$count</span>=0<span>;</span><span>echo</span><span>$count</span><span>;</span><span>$count</span>++<span>;}test();test();test();test();test();</span>

  请问这一段代码的执行结果是多少?是00000么?必然不是。是01234。首先第一次调用test(),static对 $count 进行初始化,其后每一次执行完都会保留 $count 的值,不再进行初始化,相当于直接忽略了 static$count=0; 这一句。

  因而将static应用到递归函数作用可想而知。在将需要作为递归函数间作为“桥梁”的变量利用static进行初始化,每一次递归都会保留”桥梁变量”的值。

<span>function</span> test(<span>$a</span>=0<span>){    </span><span>static</span><span>$result</span>=<span>array</span><span>();    </span><span>$a</span>++<span>;    </span><span>if</span> (<span>$a</span><10<span>) {        </span><span>$result</span>[]=<span>$a</span><span>;        test(</span><span>$a</span><span>);    }    </span><span>return</span><span>$result</span><span>;}</span>

总结

  所谓递归函数,重点是如何处理函数调用自身是如何保证所需要的结果得以在函数间合理”传递”,当然也有不需要函数之间传值得递归函数,例如:

<span>function</span> test(<span>$a</span>=0<span>){    </span><span>$a</span>++<span>;    </span><span>if</span> (<span>$a</span><10<span>) {        </span><span>echo</span><span>$a</span><span>;        test(</span><span>$a</span><span>);    }}</span>

  面对这样的函数,我们就不必大伤脑筋了。顺便说一句,深入理解变量引用相关知识对解决这类问题大有裨益。

以上就介绍了php 递归函数的三种实现方式,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php 递归函数的三种实现方式

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址