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

为什么这个地方的return 1 去掉,结果也对?

#include <stdio.h>

int getPeachNumber(n)

{

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

    if(n==10)

    {

       num=1;

        (return 1;)                 //为什么这个地方的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;

}


正在回答

4 回答

return 1和上句的num=1重复了啊,因为第10天只剩下一个桃子了,再吃就没有了,所以这里num=1或者return 1均为结束递归的条件,只要一个就可以了

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

小白一个求大神带 提问者

如果没有return 1那getPeachNumber(10)又怎么能有值呢,仅仅num=1应该是不会给getPeachNumber(10)赋值吧。
2019-02-27 回复 有任何疑惑可以回复我~
#2

sudoRam

再吃就没有了,神解
2019-03-27 回复 有任何疑惑可以回复我~
#3

L_Ab 回复 sudoRam

还能吃半个 ,
2019-04-04 回复 有任何疑惑可以回复我~

不是 num = 1;

      return 1;

都有的么?


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

其实实际上是这样写的

int getPeachNumber(n)

{

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

    if(n==10)

    {

        num = 1;   

        printf("第%d天所剩桃子%d个\n",n,num);

    } 

    else

    {

        num = (getPeachNumber(n+1)+1)*2;   //这里是不应该用递归呢?

        printf("第%d天所剩桃子%d个\n",n,num); //天数,所剩桃子个数

    }

    return num;

}

这样更符合单一出口的原则,答案是简化了

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

应该用return 1;只用num=1;结果是不对的。

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

举报

0/150
提交
取消

为什么这个地方的return 1 去掉,结果也对?

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