第四届蓝桥杯【省赛试题1】高斯日记
题目描述: 大数学家高斯有个好习惯:无论如何都要记日记。 他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210 后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢? 高斯出生于:1777年4月30日。 在高斯发现的一个重要定理的日记上标注着:5343,因此可算出那天是:1791年12月15日。 高斯获得博士学位的那天日记上标着:8113 请你算出高斯获得博士学位的年月日。
提交答案的格式是:yyyy-mm-dd, 例如:1980-03-21 请严格按照格式,通过浏览器提交答案。 注意:只提交这个日期,不要写其它附加内容,比如:说明性的文字。
题目答案:
1799-07-16
题目思路:
题目要求1777年4月30日起8113天后是多少年多少月多少日,并且给出1777年4月30日起5343天后是1791年12月15日。那么我们可以通过写程序来计算,然后通过给出的1791年12月15日数据来测试程序。
题目代码:
#include<cstdio> using namespace std; int y1[12] = {31,28,31,30,31,30,31,31,30,31,30,31};//平年 int y2[12] = {31,29,31,30,31,30,31,31,30,31,30,31};//闰年 //判断闰年 bool isLeap(int y){ if((y%4==0&&y%100!=0)||(y%400==0))return true; return false; } // y m d 分别表示年月日 int y = 1777; int m = 0; int d = 8113+31+28+31+30; //int d = 5343+31+28+31+30; int main(){ //计算年份 while(d>365){ if(isLeap(y)){ d-=366; y++; } else{ d-=365; y++; } } //计算月份 if(isLeap(y)){ while(d>y2[m]){ d-=y2[m]; m++; } } else{ while(d>y1[m]){ d-=y1[m]; m++; } } PRintf("%d-%02d-%02d\n",y,m+1,d-1); return 0; }