【C语言】利用递归解决猴子吃桃问题


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

 1 #include <stdio.h>
 2 int getPeachNumber(n)
 3 {
 4     int num;    //定义所剩桃子数
 5     if(n==10)
 6     {
 7         return 1;     
 8     } 
 9     else
10     {
11         num = getPeachNumber((n+1)+1)*2;   
12         printf("第%d天所剩桃子%d个\n", n, num); //天数,所剩桃子个数
13     }
14     return num;
15 }
16 int main()
17 {
18     int num = getPeachNumber(1);
19     printf("猴子第一天摘了:%d个桃子。\n", num);
20     return 0;
21 }

一句话总结递归:自我调用且有完成状态!


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM