在学习算法的过程中 很多算法在实现过程中都会用到递归 ,深入理解递归是很重要的;
看看下面这段程序
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 也能有更好的掌控
晚安 。。。。。。。