为什么结束条件num=1通不过,必须return 1?

来源:5-8 递归函数(二)

慕粉3707250

2016-07-25 17:49

#include <stdio.h>

int getPeachNumber(int n)

{

    int num;    //定义所剩桃子数

    if(n==10)

    {

       num = 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;

}

写回答 关注

2回答

  • 爱上学习2015
    2016-07-26 17:27:16

    刚刚才问同样的问题,慕粉转员的回答给我一种后然开朗的感觉,谢谢。

  • 慕粉转员
    2016-07-25 21:43:19

    num=1是将1赋值给num,这样就直接将num==1运用到接下来的程序中了。而return 1是循环第十次时,将1返回给 getPeachNumber(1),也就是getPeachNumber(1)=1。

    qq_细节造...

    他的运算虽然把num==1带入了后面的运算,但是并不影响,因为后面对num重新赋值了

    2016-08-04 16:52:28

    共 4 条回复 >

C语言入门

C语言入门视频教程,带你进入编程世界的必修课-C语言

926021 学习 · 20793 问题

查看课程

相似问题