#include <stdio.h>
int getPeachNumber(n)
{
int num; //定义所剩桃子数
if(n==10)
{
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;
}
因为第十天香蕉只有一个了, num = (getPeachNumber(n+1)+1)*2,
第十天num = 1 //return 1 (因为if判断n==10,会return 1);
第九天num = (1+1)*2 //return 4 最左边的数上次递归调用的返回值,你应该应该能看出来;
第八天num = (4+1)*2 //return 10;
以此类推......
第一天时,第二天的返回值是766,所以num = (766+1)*2; //return 1534;
第一天就返回了1534.
返回值为1吧