当前位置:首页 > PHP教程 > php应用 > 列表

PHP实现递归的三种方法

发布:smiling 来源: PHP粉丝网  添加日期:2022-03-16 15:09:02 浏览: 评论:0 

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

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

一、利用引用做参数

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

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

  1. function recursion(&$data = [], $i = 0) 
  2.  if ($i < 10) { 
  3.   $data[] = $i
  4.   $i++; 
  5.   $this->recursion($data$i); 
  6.  } 
  7.  return $data
  8. // 调用 
  9. $this->recursion(); // [0,1,2,3,4,5,6,7,8,9] 

二、利用全局变量

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

  1. function recursion($data = [], $i = 0) 
  2.  global $data
  3.  if ($i < 10) { 
  4.   $data[] = $i
  5.   $i++; 
  6.   $this->recursion($data$i); 
  7.  } 
  8.  return $data
  9.    
  10. // 调用 
  11. $this->recursion(); // [0,1,2,3,4,5,6,7,8,9] 

三、利用静态变量

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

  1. function recursion($i = 0) 
  2.  static $data = []; 
  3.  if ($i < 10) { 
  4.   $data[] = $i
  5.   $i++; 
  6.   $this->recursion($i); 
  7.  } 
  8.  return $data
  9.    
  10. // 调用 
  11. $this->recursion(); // [0,1,2,3,4,5,6,7,8,9]

Tags: PHP递归方法

分享到:

相关文章