问答详情
源自:5-8 递归函数(二)

请大神详细讲解下程序运行的顺序,实在看不懂了


#include <stdio.h>

int getPeachNumber(int 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 n;

    int num = getPeachNumber(1);

    printf("猴子第%d天摘了:%d个桃子。\n", n, num);

    return 0;

}


提问者:编程兴趣小白 2021-11-22 17:02

个回答

  • 小鸭快跑
    2022-01-22 19:18:54

    先看n=10的时候,getPeachNumber(10)=1;然后倒推,n=9的时候,num=(getPeachNumber(10)+1)*2,也就是4,依次推理可得答案;