慕盖茨4222327
2018-02-09 16:13
#include <stdio.h>
int getPeachNumber(n)
{
int num; //定义所剩桃子数
if(n==10)
{
num=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;
}
为什么return 1 是结束条件?
会不会有减少赋值使过程简化的作用??
return的作用是返回调用值,也就是递归函数中的结束条件,递归函数的特点是自我调用且有完成状态(结束条件),如果仅仅是num=1的话,就相当于没有结束条件,毕竟机器不像人一样看一眼就知道值要调用到哪里
嗯嗯 是的 运行结果没有问题。但是慕课会提示递归的结束条件那有问题。。。。所以我就较个真 想明白“结束条件难道必须按照慕课的写法?”
按照你的代码,我运行的结果,没问题啊,不需要return 1(按照你的num=1,后面return就行了)
C语言入门
926021 学习 · 20793 问题
相似问题