為什么結(jié)束條件num=1通不過,必須return 1?
#include <stdio.h>
int getPeachNumber(int n)
{
? ? int num; ? ?//定義所剩桃子數(shù)
? ? if(n==10)
? ? {
? ? ? ?num = 1; ? ? ?//遞歸結(jié)束條件
? ? }?
? ? 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;
}
2016-07-26
剛剛才問同樣的問題,慕粉轉(zhuǎn)員的回答給我一種后然開朗的感覺,謝謝。
2016-07-25
num=1是將1賦值給num,這樣就直接將num==1運(yùn)用到接下來的程序中了。而return 1是循環(huán)第十次時(shí),將1返回給?getPeachNumber(1),也就是getPeachNumber(1)=1。