為什么這個(gè)地方的return 1 去掉,結(jié)果也對(duì)?
#include <stdio.h>
int getPeachNumber(n)
{
? ? int num;? ? //定義所剩桃子數(shù)
? ? if(n==10)
? ? {
? ? ? ?num=1;
????????(return 1;)? ? ? ? ? ? ? ? ?//為什么這個(gè)地方的return 1 去掉,結(jié)果也對(duì)?
? ? ? }?
? ? else
? ? {
? ? ? ? num = (getPeachNumber(n+1)+1)*2;? ?//這里是不應(yīng)該用遞歸呢?
? ? ? ? printf("第%d天所剩桃子%d個(gè)\n", n, num); //天數(shù),所剩桃子個(gè)數(shù)
? ? }
? ? return num;
}
int main()
{
? ? int num = getPeachNumber(1);
? ? printf("猴子第一天摘了:%d個(gè)桃子。\n", num);
? ? return 0;
}
2019-02-20
return 1和上句的num=1重復(fù)了啊,因?yàn)榈?0天只剩下一個(gè)桃子了,再吃就沒有了,所以這里num=1或者return 1均為結(jié)束遞歸的條件,只要一個(gè)就可以了
2019-07-03
不是 num = 1;
? ? ? return 1;
都有的么?
2019-04-18
其實(shí)實(shí)際上是這樣寫的
int getPeachNumber(n)
{
? ? int num;? ? //定義所剩桃子數(shù)
? ? if(n==10)
? ? {
? ? ? ? num = 1;? ?
? ? ? ? printf("第%d天所剩桃子%d個(gè)\n",n,num);
? ? }?
? ? else
? ? {
? ? ? ? num = (getPeachNumber(n+1)+1)*2;? ?//這里是不應(yīng)該用遞歸呢?
? ? ? ? printf("第%d天所剩桃子%d個(gè)\n",n,num); //天數(shù),所剩桃子個(gè)數(shù)
? ? }
? ? return num;
}
這樣更符合單一出口的原則,答案是簡(jiǎn)化了
2019-03-02
應(yīng)該用return 1;只用num=1;結(jié)果是不對(duì)的。