第四届蓝桥杯【省赛试题1】高斯日记
来源:互联网 发布:美工和ui设计师的区别 编辑:程序博客网 时间:2024/05/16 12:16
题目描述:
大数学家高斯有个好习惯:无论如何都要记日记。
他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如: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;}
1 0
- 第四届蓝桥杯【省赛试题1】高斯日记
- 第四届蓝桥杯 高斯日记
- 第四届蓝桥杯C++A组——高斯日记
- “蓝桥杯”第四届本科B组预赛试题: 高斯日记
- 蓝桥杯第四届预赛1高斯日记
- 第四届蓝桥杯值之高斯日记
- 第四届_高斯日记
- 2013蓝桥杯【初赛试题】高斯日记
- 高斯日记-2013年第四届蓝桥杯软件大赛预赛第一题。
- 山东省第四届蓝桥杯 ///题目标题: 高斯日记//c/c++组
- 2013年第四届蓝桥杯C/C++程序设计本科B组省赛 高斯日记(结果填空)
- 蓝桥杯第四届 高斯日记(excel)
- (蓝桥杯第四届B组)高斯日记
- 第四届蓝桥杯【省赛试题9】带分数
- 蓝桥杯 历届试题 高斯日记 马虎的算式
- 第四届蓝桥杯【省赛试题2】马虎的算式
- 第四届蓝桥杯【省赛试题3】第39级台阶
- 第四届蓝桥杯【省赛试题4】黄金连分数
- [LeetCode]133. Clone Graph
- 关于ASP.NET Web Api的HelpPage文档注释问题
- Java web给Android写接口时用SQL Sever2014所遇到的大坑
- 项目设计思想学习
- 341. Flatten Nested List Iterator
- 第四届蓝桥杯【省赛试题1】高斯日记
- 北大、宾州语法树标记集合
- JAVA向上转型和向下转型(一)
- 2017-03-04 天天爱旅游
- 优化方法
- HDU 2141 can you find it?
- 将一个字符串中的空格字符替换成另外一个字符串
- android Shape Drawable创建两边半圆的按钮背景【转】
- POJ3356:AGTC(最小编辑距离问题)