2013蓝桥杯【初赛试题】高斯日记

简介:

高斯日记
大数学家高斯有个好习惯:无论如何都要记日记。
他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210
后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?
高斯出生于:1777年4月30日。
在高斯发现的一个重要定理的日记上标注着:5343,因此可算出那天是:1791年12月15日。
高斯获得博士学位的那天日记上标着:8113
请你算出高斯获得博士学位的年月日。

提交答案的格式是:yyyy-mm-dd, 例如:1980-03-21
请严格按照格式,通过浏览器提交答案。
注意:只提交这个日期,不要写其它附加内容,比如:说明性的文字。

 

 

#include<stdio.h>
int Run(int n)//判断闰年的函数
{
    if(n%400==0||(n%100!=0&&n%4==0)) return 1;
    return 0;
}
int month(int n,int year)//根据年份,判断月份的天数
{
    switch(n)
    {
             case 1:return 31;break; 
             case 2:{
                      if(Run(year))
                      return 29;
                      else
                      return 28;
                      break;
                  }
             case 3:return 31;break;
             case 4:return 30;break;
             case 5:return 31;break;
             case 6:return 30;break;
             case 7:return 31;break;
             case 8:return 31;break;
             case 9:return 30;break;
             case 10:return 31;break;
             case 11:return 30;break;
             case 12:return 31;break;
    }
    
}
int main()
{
    int i,j,flag,n,m,sum,x;
    scanf("%d",&n);
    m=1777;sum=0;
    for(i=5;i<=12;i++)
    sum+=month(i,1777);//这个代码只能算超过1778年的
    for(i=1779;i<2000;i++)
    {
      if(Run(i)==1)
      {
         if(sum+366>=n)
         {
           flag=i-1;
           break;
         }
         else
         sum+=366;
      }
      else
      {
          if(sum+365>=n)
          {
            flag=i-1;
            break;
          }
          else
          sum+=365;
      }
    }
    if(sum!=n)
    {
        for(i=1;i<=12;i++)
       {
           if(sum+month(i,flag)<n)
           sum+=month(i,flag);
           else
           {
               if(sum+month(i,flag)==n)
               {
                   printf("%d-%d-%d\n",flag,i,month(i,flag));
                   break;
               }
               else
               {
                   x=0;
                   while(sum!=n)
                   {
                      sum+=1;
                      x+=1;
                   }
                   printf("%d-%d-%d\n",flag,i,x-1);//题中4月30那一天也算,所以算出的天数要减去一
                   break;
               }
           }
       }
    }
    return 0;
}


 

相关文章
|
9月前
|
机器学习/深度学习 算法 C++
2019第十届蓝桥杯大赛青少年创意编程省赛C++组试题解析
2019第十届蓝桥杯大赛青少年创意编程省赛C++组试题解析
227 0
|
2月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-940 试题3971
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-940 试题3971
26 0
|
3月前
|
Java
第十三届蓝桥杯B组Java(试题B:山)
第十三届蓝桥杯B组Java(试题B:山)
29 0
|
3月前
|
C++
第十三届蓝桥杯B组C++(试题B:顺子日期)
第十三届蓝桥杯B组C++(试题B:顺子日期)
50 0
|
4月前
|
算法
蓝桥杯-试题 算法训练 数据交换
蓝桥杯-试题 算法训练 数据交换
22 0
|
4月前
蓝桥杯vip试题 报时助手
蓝桥杯vip试题 报时助手
28 0
|
4月前
|
算法
蓝桥杯vip测试题系统试题-算法提高 矩阵转置
蓝桥杯vip测试题系统试题-算法提高 矩阵转置
27 0
|
Java
第十一届蓝桥杯A组省赛填空试题 D: 七段码(Java)
第十一届蓝桥杯A组省赛填空试题 D: 七段码(Java)
140 0
第十一届蓝桥杯A组省赛填空试题 D: 七段码(Java)
|
10月前
|
Java
【java蓝桥杯基础试题】十六进制转十进制
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。   注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
89 0
|
10月前
|
存储 人工智能 测试技术
第十四届蓝桥杯省赛JavaB组试题E【蜗牛】Dijkstra堆优化 or 线性DP?
第十四届蓝桥杯省赛JavaB组试题E【蜗牛】Dijkstra堆优化 or 线性DP?
第十四届蓝桥杯省赛JavaB组试题E【蜗牛】Dijkstra堆优化 or 线性DP?