weixin_慕后端5085378
2020-04-08 15:19
#include <stdio.h>
int getPeachNumber(n)
{
int num; //定义所剩桃子数
if(n==10)
{
return 1; //递归结束条件
}
else
{
num = getPeachNumber(n)-n/2-1; //这里是不应该用递归呢?
printf("第%d天所剩桃子%d个\n",n,num); //天数,所剩桃子个数
}
return num;
}
int main()
{
int num = getPeachNumber(1);
printf("猴子第一天摘了:%d个桃子。\n", num);
return 0;
}
求大神,这个程序有错但是他说我编译成功了,哪里错了?
num = getPeachNumber(n)-n/2-1; 这个递归条件有问题。
正确的应该是这样:num = (getPeachNumber(n+1)+1)*2;
这是从第10天往后倒推的递归。第10天剩一个,第9天剩(第十天剩的个数+1)*2 。然后再算第八天,第七天... 最后算到第一天。剩的个数我们用函数表示f(x),这样,f(9)=(f(10)+1)*2.
C语言入门
926020 学习 · 20793 问题
相似问题