c語言入門之, 5-8 遞歸函數
#include <stdio.h>
int getPeachNumber(n)
{
? ? int num; ? ?//定義所剩桃子數
? ? if(n==10)
? ? {
? ? num=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;
}
代碼中, ? n代表天數, ?num代表桃子數,而(getPeachNumber是什么意思呢?
(getPeachNumber(n+1)+1)*2; ? , ?加一是因為它多吃了一個, *2是因為吃了一半,可是為什么要加兩次一呢, ?不太理解,?
求解。 謝謝。
2017-05-30
getPeachNumber(n+1)中的n+1代表的是天數,n是今天,n+1是第二天。所以?getPeachNumber(n+1) 就是指第二天的桃子數。(getPeachNumber(n+1)+1)*2 就是指第二天的桃子數加1再乘與兩倍,得到今天的桃子數。