递归调用步骤记录

在这里插入图片描述

递归调用是一种特殊的嵌套调用,是某个函数调用自己或者是调用其他函数后再次调用自己的,只要函数之间互相调用能产生循环的则一定是递归调用,递归调用一种解决方案,一种是逻辑思想,将一个大工作分为逐渐减小的小工作,比如说一个和尚要搬50块石头,他想,只要先搬走49块,那剩下的一块就能搬完了,然后考虑那49块,只要先搬走48块,那剩下的一块就能搬完了,递归是一种思想,只不过在程序中,就是依靠函数嵌套这个特性来实现了。

示例:递归求解一个数累计相加的结果

   public function fn($n)
    {
        if ($n == 1) {
            return 1;
        }
        return $n + fn($n - 1);
    }

步骤:

序号	  返回值    参数     计算/定值
	A      15       5        5+ fn(5-1)    5+B返回值
	B	   10       4        4+ fn(4-1)    4+C返回值
	C	   6        3        3+ fn(3-1)    3+D返回值
	D	   3        2        2+ fn(2-1)    2+E返回值
	E	   1        1        返回定值 1

  • 递归执行公式比如传入数值是5,公式代进去表示成 5+fn(5-1)第一步靠人脑是可以补充出来的。定值表示递归终止返回的值 比如 $n == 1 定值返回return 里面定义的值。
  • 处理完按照返回值重下往上计算 把返回值带进公式即可。
  • 递归也就是把一个问题区分成小问题来解决。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吃橘子的汤圆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值