递归

在学习算法的过程中 很多算法在实现过程中都会用到递归 ,深入理解递归是很重要的;

看看下面这段程序

 function test($i) {
   if($i<10){
       ++$i;
       test($i);
   }
   echo $i;
    //return $i;
}
 test(1);

输出什么呢????
是:2,3,4,5,6,7,8,9, 10,10 吗?
如果想当然 你就会认为是上面的答案
真正的输出是:
10,10,9,8,7,6,5,4,3,2
为什么是反着来的呢?

如果写想下面这样写 可能就能更好理解了

 function test($i) {
   if($i<10){
       ++$i;
       if($i<10){
           ++$i;
           ....//继续下去
       }
       echo $i;
   }
   echo $i;
    //return $i;
}
 test(1);

相当于每一层执行的时候都没执行到echo 语句 ,当执行到最后一步的时候再一步步向外层执行 echo 语句
从这里可以看到 递归是一种深度探索执行 然后探索结束后再逐步回头的过程 这特点适合于深度优先执行的一些算法 比如回溯算法

来看看快速排序

function quick_sort($arr){
     $n=count($arr);
    if($n<=1)
        return $arr;
    $key=$arr[0];
    $left_arr=array();
    $right_arr=array();
    for($i=1;$i<$n;$i++) {
        if($arr[$i]<=$key)
            $left_arr[]=$arr[$i];
        else
            $right_arr[]=$arr[$i];
    }
    $left_arr=quick_sort($left_arr);
    $right_arr=quick_sort($right_arr);
    $arr = array_merge($left_arr,array($key),$right_arr);
    print_r($arr);
    echo "<br/>-------------<br/>";
    return $arr;
}
quick_sort(array(5,6,8,3,6,9,2,1,4))

输出什么呢?
两次递归 那么就应该是类似中序的二叉树遍历,左边 merger(中) 右边 所以输出应该是下面这样的:

Array ( [0] => 1 [1] => 2 )

Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 )

Array ( [0] => 8 [1] => 9 )

Array ( [0] => 6 [1] => 6 [2] => 8 [3] => 9 )

Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 [6] => 6 [7] => 8 [8] => 9 ) ;

那看看下面这段代码

function test($i){ 
    $i-=4; 
    if($i<3){ 
        return $i; 
    }else{ 
        test($i); 
    } 
} 
echo test(30); 

为何这段代码没有返回呢??明白上面说的 你就能知道为什么了 在递归调用时 进行深度执行 共执行了7层的深度 执行结束时 i=2; i的值 当然什么都不输出了;要正常输出需要携程return test(i); 当然只有一层的时候就能正常返回了 比如执行 echo test(5) 就能正常输出1;

好了 相信通过上面的研究 应该大家都能对递归有清晰认识 在递归中的echo 以及 return 也能有更好的掌控

晚安 。。。。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值