使用PHP实现递归的三种方式

2017-10-22 PHP
      递归函数是大家经常会使用的,它在函数体内部直接或者间接的自己调用自己,必须在调用自身前有条件判断,否则无限无限调用下去。前面的章节什么是php递归函数以及介绍一个简单的实例来说明。这一节我们来介绍php如何实现递归函数的几种方法。这里列出了三种基本方式。理解其原来需要一定的基础知识水平,包括对全局变量,引用,静态变量的理解,也需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好地技巧。

一、利用引用做参数

      引用不过是指两个不同名的变量指向同一块存储地址。本来每个变量有各自的存储地址,赋值删除各行其道。现在需要两个变量共享一块存储地址。 $a=&$b; 。实际上指的是 $a 不管不顾自己原来的存储地址,非要和 $b 共享一个房间了。因而任何对存储地址数值的改变都会影响两个值。  

  函数之间本来也是各行其是,即便是同名函数。递归函数是考虑将引用作为参数,成为一个桥梁,形成两个函数间的数据共享。虽然两个函数见貌似操作的是不同地址,但是实际上操作的是一块儿内存地址。

下面通过实例来看一下:
 

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

 

上面的例子,以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在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。但一旦用了&,同名变量将不再是同名引用。

下面来举个例子说明:

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

 

三、利用静态变量

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

下面用实例来说明一下:
 

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

      说明:这一段代码的执行结果是多少?大家可能会认为是00000,答案当然是否定的。输出的结果是01234。首先第一次调用test(), static 对 $count 进行初始化,其后每一次执行完都会保留 $count 的值,不再进行初始化,相当于直接忽略了 static $count=0; 这一句。因而将static应用到递归函数作用可想而知。在将需要作为递归函数间作为“桥梁"的变量利用static进行初始化,每一次递归都会保留"桥梁变量"的值。

总结

  所谓递归函数,重点是如何处理函数调用自身是如何保证所需要的结果得以在函数间合理"传递"。以上就是php实现递归的三种基本方式,朋友们可以自行进行各种代码尝试,以便更好更熟练的掌握这些方法,为以后的学习开发打下良好的基础。