php递归函数的理解

   public function digui($i)
    {

        if($i=='1'){
            echo  "*" ;
            echo "<br>";
            return ;
        }else{
            $this->digui($i-1);
            for($j=1;$j<=$i;$j++){
                echo  "*" ;
            }
            echo "<br>";
        }

    }

 调用 $this->digui(3);

结果

*
**
***


  function digui2($n){
        echo $n." ";
        if($n>0){
            $this-> digui2($n-1);
        }else{
            echo "<-->";
        }
        echo $n." ";
    }

 调用 $this->digui2(3);

结果

3 2 1 0 <-->0 1 2 3


 



递归函数执行 解剖 实例 (转载别人的)

看如下代码:


<?php
function one($num){
echo $num;
two($num-1);
echo $num;
}
function two($num){
echo $num;
three($num-1);
echo $num;
}
function three($num){
echo $num;
}
one(3);
?>


以上代码对test()函数进行分解操作,我们思考:




执行one(3)函数的时候,同test()函数一样,首先要输出3,然后调用two(2)函数,




注意,此时还没有输出下面的3,




接着走,执行two(2)函数,输出2,调用three(1)函数,同样,这里没有来得及输出下面的2,




执行three(1),直接输出1,不在调用其它函数,




此时,我们想刚刚的two()函数是不是还没有执行完,好,接着执行two()函数没有完成的部分,two()函数执行完之后,也就是输出下面的2,然后开始执行one()函数没有执行完的部分,也就是输出下面的3,此时所有函数执行完毕。




那么,输出结果是:




3 2 1 2 3


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果你需要将多个 PHP 递归函数的结果合并一起返回,可以使用 PHP 的 `array_merge()` 函数来实现。以下是示例代码: ```php function recursive($n) { if ($n == 1) { return array(1); } else { $result = array($n); $result = array_merge($result, recursive($n - 1)); return $result; } } function multipleRecursive($n) { if ($n == 1) { return array(array(1)); } else { $result = array(); $prev = multipleRecursive($n - 1); foreach ($prev as $p) { $result[] = recursive($n); $result[] = $p; } return $result; } } print_r(multipleRecursive(3)); ``` 输出: ``` Array ( [0] => Array ( [0] => 3 [1] => 2 [2] => 1 ) [1] => Array ( [0] => 2 [1] => 1 ) [2] => Array ( [0] => 3 [1] => 1 ) [3] => Array ( [0] => 1 ) ) ``` 在上面的例子中,`recursive()` 函数返回从 $n 到 1 的整数数组。`multipleRecursive()` 函数用递归方式来构建一个由多个 `recursive()` 函数的结果组成的数组。`multipleRecursive()` 函数返回一个数组,其中包含所有子递归函数的结果的合并。在这里,我们使用了 `array_merge()` 函数将一个数组与另一个数组合并。 ### 回答2: 在PHP中,递归是一种算法,它允许函数在调用自身的情况下解决问题。当递归函数执行时,它将重复执行自身的代码,直到满足终止条件。 要将递归结果合并一起返回,我们可以通过传递一个空数组作为参数,并在每个递归调用中将结果合并到该数组中。以下是一个示例函数,可以递归地计算从1到给定数字的总和,并将所有计算结果合并到一个数组中返回。 ```php function recursiveSum($n, $result = array()) { if ($n <= 0) { return $result; } $result[] = $n; // 将当前数字添加到结果数组中 return recursiveSum($n - 1, $result); } $number = 5; $result = recursiveSum($number); echo "从1到" . $number . "的和为:" . array_sum($result); ``` 在上面的示例中,`recursiveSum`函数接受一个参数`$n`表示要计算的数字范围,并传递一个额外的参数`$result`作为结果数组。如果`$n`小于或等于0,则返回结果数组。 在每个递归调用中,将当前数字`$n`添加到结果数组中,然后通过调用`recursiveSum`函数来递归计算下一个数字的和,并传递更新后的结果数组。 最后,我们可以使用`array_sum`函数计算结果数组中所有数字的总和,并将其打印出来。 希望这个示例能帮助你理解如何在PHP中将递归结果合并一起返回。 ### 回答3: PHP递归是指在函数体内调用自身的过程,可以用于解决一些需要重复执行的问题。递归的结果可以通过合并返回。 在PHP中,可以通过引用参数的方式将递归结果合并返回。具体实现如下: ``` function mergeResults(&$result, $data) { // 检查数据是否是数组 if (is_array($data)) { // 遍历数组中的每个元素 foreach ($data as $item) { // 如果元素是数组,继续递归调用mergeResults函数 if (is_array($item)) { mergeResults($result, $item); } else { // 如果元素是基本数据类型,将其添加到结果数组$result中 $result[] = $item; } } } } // 主函数入口 function main() { $data = [1, 2, [3, 4, [5, 6]], 7, [8, 9]]; $result = []; // 调用mergeResults函数进行递归合并 mergeResults($result, $data); // 打印合并后的结果 foreach ($result as $item) { echo $item . " "; } } // 调用主函数 main(); ``` 上述代码中,`mergeResults`函数接收两个参数:`$result`表示递归合并后的结果,`$data`表示待合并的数据。在递归过程中,如果当前元素是数组,则继续递归调用`mergeResults`函数处理子数组;如果当前元素是基本数据类型,则直接将其添加到结果数组`$result`中。最终,合并后的结果保存在`$result`数组中。 在主函数`main`中,我们传入一个包含嵌套数组的示例数据`$data`,然后调用`mergeResults`函数进行递归合并。最后,使用foreach循环遍历`$result`数组,并打印出合并后的结果。 运行上述代码,输出结果为:`1 2 3 4 5 6 7 8 9`,表示成功将递归结果合并并返回。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值