[C] C语言 猴子吃桃问题 →→→→→进入此内容的聊天室

来自 Beefy Gibbon, 2024-03-21, 写在 C, 查看 14 次.
URL http://www.code666.cn/view/5c1b418d
  1. 题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个
第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下
的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
  2.  
  3. 程序分析:采取逆向思维的方法,从后往前推断。
  4.  
  5. 1) 设x1为前一天桃子数,设x2为第二天桃子数, 则:
  6.  
  7. x2=x1/2-1, x1=(x2+1)*2
  8.  
  9. x3=x2/2-1, x2=(x3+1)*2
  10.  
  11. 以此类推: x前=(x后+1)*2
  12.  
  13. 2) 从第10天可以类推到第1天,是一个循环过程。
  14.  
  15.  
  16. #include <stdio.h>
  17. #include <stdlib.h>
  18. int main(){
  19.     int day, x1 = 0, x2;
  20.     day=9;
  21.     x2=1;
  22.     while(day>0) {
  23.         x1=(x2+1)*2;  // 第一天的桃子数是第2天桃子数加1后的2倍
  24.         x2=x1;
  25.         day--;
  26.     }
  27.     printf("总数为 %d\n",x1);
  28.    
  29.     return 0;
  30. }

回复 "C语言 猴子吃桃问题"

这儿你可以回复上面这条便签

captcha