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

对getPeachNumber

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

求教,对getPeachNumber(n)函数产生疑惑

请问

①n在哪被定义了,n在一开始被格式化为9了吗?

②本函数是从第10天余下1个桃子的起点开始算,一路推至第1天的桃子数量吗?

③如果②的答案是从第10天开始推算,为什么是getPeachNumber(n+1)而不是getPeachNumber(n-1),天数不是在逐级减少吗?

以上

正在回答

1 回答

补充:

是不是在num1=(getPeachNumber(n+1)+1)*2时,代入的第一个n=1

即num1=(getPeachNumber(2)+1)*2

为了算出num1=(getPeachNumber(2)+1)*2,

有num2=(getPeachNumber(3)+1)*2

...

依此类推

直至num9=(getPeachNumber(10)+1)*2

因为getPeachNumber(10)=1,所以从这里开始反向输出

输出num9=(1+1)*2

输出num8=(((1+1)*2)+1)*2

...
依此类推

直至num1=最终答案


总而言之是不是这个函数为了算出最初的num1开始不断以类似循环的形式开始推数,达到限制(即num10)时开始从num9输出至原点num1?

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

举报

0/150
提交
取消

对getPeachNumber

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