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

这里面的return 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;

}


提问者:qq_Sun_kuxKSU 2018-10-28 16:58

个回答

  • 遗失的美好灬
    2018-10-29 10:47:15

    因为第十天香蕉只有一个了, num = (getPeachNumber(n+1)+1)*2,

    第十天num = 1    //return 1       (因为if判断n==10,会return 1);

    第九天num = (1+1)*2    //return 4        最左边的数上次递归调用的返回值,你应该应该能看出来;        

    第八天num = (4+1)*2    //return 10;

    以此类推......

    第一天时,第二天的返回值是766,所以num = (766+1)*2;  //return 1534;

    第一天就返回了1534.


  • 慕函数3906388
    2018-10-28 19:32:23

    返回值为1吧