解题思路:

  1. 设开始时有n个桃子,第一天吃了一半则还剩余一半即n/2个,再吃一个还剩n/2-1个。
  2. 每天剩余的个数都是前一天的一半再减去1个。
  3. 据1和2列出下表:
  4. 设猴子第day天准备吃时发现只有一个,则说明第day-1天剩余1个。
    如第4天准备吃时发现只有一个即:第3天剩余1个,则有(n-2-4-8)/8=1
    即(n-(2+4+8))/(2^3)=1;故n=2+4+8+8=(以2为首相,公比为2的等比数列的前三项和再加上第三项)。
  5. 归纳法得第day天剩余一个时,求n的通式为:n=(以2为首相,公比为2的等比数列的前day项和再加上第day项)

参考代码:

  1. #include<stdio.h>
  2. #include<math.h>
  3. int main()
  4. {
  5. int day;
  6. while(scanf("%d",&day)!=EOF)
  7. {
  8. printf("%.0lf\n",-2*(1-pow(2,day-1))+pow(2,day-1));
  9. }
  10. return 0;
  11. }
注意事项:
  1. pow() 返回值为浮点型。
点赞(0)
 

8.8 分

1 人评分

 

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论