阿Qs
2019-06-25 07:24
#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 递归的过程就是如下
getPeachNumber(1) -->getPeachNumber(1) ... --> getPeachNumber(10)
getPeachNumber(10) 返回的只是1,没有printf ,然后就在往上到
getPeachNumber(9) =(getPeachNumber(10)+1)*2 =4 ,然后输出就是第九天,把4返回给上一级
C语言入门
926020 学习 · 20793 问题
相似问题