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

第9天所剩桃子4个桃子,这里面这个9是怎么算出来的啊?最开始int num = getPeachNumber(1);不是只给了1吗?

#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;
}

正在回答

1 回答

递归 num = (getPeachNumber(n+1)+1)*2 递归的过程就是如下

getPeachNumber(1) -->getPeachNumber(1)  ... --> getPeachNumber(10) 

getPeachNumber(10) 返回的只是1,没有printf ,然后就在往上到 

getPeachNumber(9) =(getPeachNumber(10)+1)*2 =4 ,然后输出就是第九天,把4返回给上一级


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

举报

0/150
提交
取消

第9天所剩桃子4个桃子,这里面这个9是怎么算出来的啊?最开始int num = getPeachNumber(1);不是只给了1吗?

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