• 技术文章 >后端开发 >PHP问题

    php实现递归的方法是什么

    coldplay.xixicoldplay.xixi2020-08-21 13:45:58原创626

    php实现递归的方法是:1、利用引用做参数,代码为【$result[]=$a;test($a,$result)】;2、利用全局变量;3、利用静态变量,代码为【static $count=0;】。

    【相关学习推荐:php图文教程

    php实现递归的方法是:

    一、利用引用做参数

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

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

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

      上面的例子非常简答,以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。为什么呢?因为函数还没执行echoa前就进行了下一次的函数递归。真正执行echo a是当a<10条件不满足的时候,echo a,返回result,对于上一层而言,执行完递归函数,开始执行本层的echo $a,依次类推。

    例子二、

    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 test($a=0,$result=array()){
     global $result;
     $a++;
     if ($a<10) {
      $result[]=$a;
      test($a,$result);
     }
     return $result;
    }

    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]

    三、利用静态变量

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

      举个栗子:

    function test(){
    static $count=0;
    echo $count;
     
    $count++;
    }
    test();
    test();
    test();
    test();
    test();

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

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

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

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

    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实现递归的方法是什么的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:php 递归
    上一篇:如何更改首页默认index.php改成index.html 下一篇:php如何删除txt文件内容
    大前端线上培训班

    相关文章推荐

    • PHP递归函数用法• 什么是递归?• php如何递归删除文件• php递归删除目录的方法

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网