C语言作业:用递归法怎么做猴子摘桃?知道的大哥大姐帮帮忙!

 我来答
碧海风云

2017-07-14 · 碧海风的秘密小据点!
碧海风云
采纳数:909 获赞数:10281

向TA提问 私信TA
展开全部

猴子摘桃问题

猴子第一天摘下N个桃子,当时就吃了一半,还不过瘾,就又多吃了一个。第二天又将剩下的桃子吃掉一半,又多吃了一个。以后每天都吃前一天剩下的一半零一个。到第10天在想吃的时候就剩一个桃子了,问第一天共摘下来多少个桃子?

#include <stdio.h>  

int getPeachNumber (n) {  
int num; /* 定义所剩桃子数 */
if(n==10)
       return 1; /*递归结束条件 */
    else {  
num = getPeachNumber(n+1)*2 + 2; /* 递归 */
printf("第%d天所剩桃子%d个\n", n, num); /* 天数,所剩桃子个数 */
}
return num;
}

int main (void) {  
int num = getPeachNumber(1);  
printf("猴子第一天摘了%d个桃子。\n", num);

getch (); /* 屏幕暂留 */
return 0;  
}

运行结果

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式