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

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

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

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

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

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

1 回复 有任何疑惑可以回复我~
#1

慕斯卡6439517

可是计算结果是一样的,这两种方法应该都对吧
2016-07-26 回复 有任何疑惑可以回复我~
#2

慕粉3707250 提问者

但是接下来不就运行到“return num”了吗?
2016-07-29 回复 有任何疑惑可以回复我~
#3

qq_细节造就完美男人_0 回复 慕斯卡6439517

对的,只是你的程序多了一步运算。没什么区别。
2016-08-04 回复 有任何疑惑可以回复我~
#4

qq_细节造就完美男人_0

他的运算虽然把num==1带入了后面的运算,但是并不影响,因为后面对num重新赋值了
2016-08-04 回复 有任何疑惑可以回复我~
查看1条回复

举报

0/150
提交
取消

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

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