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

结束递归没用到return 1;而是num = 1;正常工作了什么原理

#include <stdio.h>
int getPeachNumber(n)
{
    int num;    //定义所剩桃子数
    if(n==10)
    {
       num = 1;       //递归结束条件
    }
    else
    {
        num = 2*(getPeachNumber(n+1)+1);   //这里是不应该用递归呢?
        printf("第%d天所剩桃子%d个\n", n, num); //天数,所剩桃子个数
    }
    return num;
}
int main()
{
    int num = getPeachNumber(1);
    printf("猴子第一天摘了:%d个桃子。\n", num);
    return 0;
}

第9天所剩桃子4个
第8天所剩桃子10个
第7天所剩桃子22个
第6天所剩桃子46个
第5天所剩桃子94个
第4天所剩桃子190个
第3天所剩桃子382个
第2天所剩桃子766个
第1天所剩桃子1534个
猴子第一天摘了:1534个桃子。

提问者:人間世界 2015-07-05 10:57

个回答

  • 人間世界
    2015-07-05 11:00:16

    ..在if里没有return,结束if在总的return num里return了.