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;
}


 

相关文章
|
6月前
|
人工智能 算法 Java
第十三届蓝桥杯B组Java(试题C:字符统计)
第十三届蓝桥杯B组Java(试题C:字符统计)
90 0
|
机器学习/深度学习 算法 C++
2019第十届蓝桥杯大赛青少年创意编程省赛C++组试题解析
2019第十届蓝桥杯大赛青少年创意编程省赛C++组试题解析
410 0
|
29天前
|
人工智能 Python
蓝桥杯练习题(四):Python组之历届试题三十题
关于蓝桥杯Python组历届试题的三十个练习题的总结,包括题目描述、输入输出格式、样例输入输出以及部分题目的解题思路和代码实现。
25 0
蓝桥杯练习题(四):Python组之历届试题三十题
|
6月前
|
机器学习/深度学习 人工智能 算法
2024 蓝桥杯本科B组试题
2024 蓝桥杯本科B组试题
105 0
蓝桥杯Java-B组2015年试题解题笔记
蓝桥杯Java-B组2015年试题解题笔记
|
数据格式
蓝桥杯Java-B组2014年试题解题笔记(下)
蓝桥杯Java-B组2014年试题解题笔记(下)
|
6月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-940 试题3971
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-940 试题3971
60 0
|
6月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 十六进制转八进制
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 十六进制转八进制
37 0
|
6月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 数列排序(四种语言对照)
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-试题 基础练习 数列排序(四种语言对照)
42 0
|
6月前
|
Python
第十三届蓝桥杯B组python(试题A:排列字母)
第十三届蓝桥杯B组python(试题A:排列字母)
63 0