利用php实现递归的方法有哪些

  介绍

这篇文章将为大家详细讲解有关利用php实现递归的方法有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

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

<>强利用引用做参数

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

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

function 测试(==0美元,和结果数组()){   $ + +;   if  (a<美元;10),{   []=美元,美元的结果;   ,测试(一个美元,导致美元);   }   echo 美元;   return 美元的结果;      }

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

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

例子二,

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

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

function 递归(和data 美元;=,[],,小姐:美元=,0)   {   if 才能;(美元小姐:& lt;, 10), {   ,,,$ data[],=,我美元;   美元,,,我+ +;   ,,,这个→美元递归($ data,我美元);   ,,}   return 才能;$数据;   }//,调用   $ this→递归();,,//,[0,1,2,3,4,5,6,7,8,9)

<>强利用全局变量

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

function 测试(=0,因此美元=array ()) {   ,global 美元的结果;   ,美元+ +;   ,if  (a<美元;10),{   结果[]=美元才能;   测试才能(a,因此美元);   ,}   ,return 美元的结果;   }

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

function 递归($ data =[]的不同之处是,小姐:美元=,0)   {   global 才能;$数据;   if 才能;(美元小姐:& lt;, 10), {   ,,,$ data[],=,我美元;   美元,,,我+ +;   ,,,这个→美元递归($ data,我美元);   ,,}   return 才能;$数据;   }   ,//,调用   $ this→递归();,,//,[0,1,2,3,4,5,6,7,8,9)

<>强利用静态变量

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

举个栗子:

function 测试(){   static  $ count=0;   echo 美元计数;      美元计数+ +;   }   测试();   测试();   测试();   测试();   测试();

利用php实现递归的方法有哪些