【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