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

我想知道这个代码的运算过程

#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 回答

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

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

getPeachNumber(3)=(getPeachNumber(4)+1)*2 

..........

getPeachNumber(8)=(getPeachNumber(9)+1)*2 

getPeachNumber(9)=(getPeachNumber(10)+1)*2 

getPeachNumber(10)=1

依次反代回去


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

举报

0/150
提交
取消

我想知道这个代码的运算过程

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