Problem Description
忙碌了一天的 bLue 累得瘫在床上,他想知道明天是几号,你能告诉他吗?
Input
输入数据有多组(数据组数不超过 50000),到 EOF 结束。
每组数据输入一行,包含用空格隔开的 3 个整数,表示今天的日期,分别为年、月、日。
保证输入日期的年份在 1900 到 2035 之间。
Output
对于每组数据,在一行中输出明天的日期,格式为 “y m d”,分别表示年、月、日。
Sample Input
2016 12 27
2016 2 29
Sample Output
2016 12 28
2016 3 1
Hint
能被 4 整除且非整百年的,或能被 400 整除的为闰年。
题解:可以从月份着手开始判断,特殊的月份,比如12月,如果是12月30日,那么明天是下一年的1月1日。特殊的月份,比如2月,若果是2月28日,要判断这一年是闰年还是平年,闰年的话明天是2月29日,平年的话明天是3月1日,如果是2月29日,那毫无疑问,明天是3月1日。其他的月份没什么特别的了。那就要注意是否是每个月的最后一天了。可以把剩下的月份分为30天的一组,31天的一组,在30天的那一组里,如果今天是30号,明天就是下一个月的1号。在31天的那一组里,如果今天是31号,明天就是下一个月的1号。剩下的日子就是加一天天数即可。
#include <stdio.h>
#include <stdlib.h>
int main()
{
int year,month,day;
while(scanf("%d %d %d",&year,&month,&day)!=EOF)
{
if(month==12)
{
if(day==31)
{
year++;
month=1;
day=1;
}
else day++;
}
else if(month==2)
{
if(day==28)
{
if((year%4==0&&year%100!=0)||year%400==0)day++;
else
{
month++;
day=1;
}
}
else if(day==29)
{
month++;
day=1;
}
else day++;
}
else if(month==4||month==6||month==9||month==11)
{
if(day==30)
{
month++;
day=1;
}
else day++;
}
else
{
if(day==31)
{
month++;
day=1;
}
else day++;
}
printf("%d %d %d\n",year,month,day);
}
return 0;
}