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是因为吃了一半,可是为什么要加两次一呢, 不太理解,
求解。 谢谢。