原题链接:蟠桃记
解题思路:
- 设开始时有n个桃子,第一天吃了一半则还剩余一半即n/2个,再吃一个还剩n/2-1个。
- 每天剩余的个数都是前一天的一半再减去1个。
- 据1和2列出下表:
- 设猴子第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的等比数列的前三项和再加上第三项)。 - 归纳法得第day天剩余一个时,求n的通式为:n=(以2为首相,公比为2的等比数列的前day项和再加上第day项)
参考代码:
#include<stdio.h>
#include<math.h>
int main()
{
int day;
while(scanf("%d",&day)!=EOF)
{
printf("%.0lf\n",-2*(1-pow(2,day-1))+pow(2,day-1));
}
return 0;
}
注意事项:
- pow() 返回值为浮点型。
8.8 分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复