为了账号安全,请及时绑定邮箱和手机立即绑定

为什么递归是num =(getPeachNumber(n+1)+1)*2

#include <stdio.h>
int getPeachNumber(n)
{
    int num;    //定义所剩桃子数
    if(n==10)
    {
       return 1;       //递归结束条件
    }
    else
    {
        num = (getPeachNumber(n+1)+1)*2;   //这里是不应该用递归呢?
        printf("第%d天所剩桃子%d个\n", n, num); //天数,所剩桃子个数
    }
    return num;
}
int main()
{
    int num = getPeachNumber(1);
    printf("猴子第一天摘了:%d个桃子。\n", num);
    return 0;
}

正在回答

3 回答

倒着来看,当n=9的时候 n+1=10 if成立 返回1 也就是说getPeachNumber(10) = 1   ||    而getPeachNumber(9) = (getPeachNumber(10)+1)*2 = (1+1)*2 = 4   ||   getPeachNumber(8) = (getPeachNumber(9)+1)*2 = 10, 然后就可以算出来了, 递归就是一个函数s(n)里面再套上s(n+1)  s(n+1)里面再套上s((n+1)+1)..... 我也是前天才开始学的,花了昨天一天才把这个递归搞的差不多懂一点. 这也只是我个人不成熟的看法 有什么不对的地方请多多包涵  : )


19 回复 有任何疑惑可以回复我~
#1

qq_致诱_nEV047

漂亮,
2018-10-15 回复 有任何疑惑可以回复我~
#2

qq_落笔与你_ijqJZ9

thank
2018-10-17 回复 有任何疑惑可以回复我~
#3

qq_松_jmuxDK

漂亮a 兄弟 我有好多不懂的地方可以教我么+
2018-11-22 回复 有任何疑惑可以回复我~

还是没看懂啊,但是他在main函数中的getPeachNumber()这个函数中实参传的是1啊,所以在else哪里的getPeachNumber()的n也是等于(getPeachNumber(1+1)+1)*2啊

1 回复 有任何疑惑可以回复我~

thank

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

为什么递归是num =(getPeachNumber(n+1)+1)*2

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信