《算法笔记》3.4小节—日期处理 问题 D: 日期类
作者:互联网
问题 D: 日期类
时间限制 : 1.000 sec 内存限制 : 32 MB
题目描述
编写一个日期类,要求按xxxx-xx-xx 的格式输出日期,实现加一天的操作。
输入
输入第一行表示测试用例的个数m,接下来m行每行有3个用空格隔开的整数,分别表示年月日。
输出
输出m行。按xxxx-xx-xx的格式输出,表示输入日期的后一天的日期。
样例输入
2
1999 10 20
2001 1 31
样例输出
1999-10-21
2001-02-01
提示
注意个位数日期前面要有0。
代码
#include<cstdio>
int month[12][2]={{31,31},{28,29},{31,31},{30,30},{31,31},{30,30},{31,31},{31,31},{30,30},{31,31},{30,30},{31,31}};
int syear(int a){
return a%400==0 || (a%4==0&&a%100!=0);
}
int main(){
int n,y,m,d;
scanf("%d",&n);
for(int i=0;i<n;i++){
scanf("%d %d %d",&y,&m,&d);
int t=syear(y);
for(int j=0;j<12;j++){
if(m-1==j){
if(d+1<=month[j][t]){
printf("%04d-%02d-%02d\n",y,m,d+1);
}
else if(m==12) printf("%04d-01-01\n",y+1);
else if(m<12) printf("%04d-%02d-01\n",y,m+1);
}
}
}
}
标签:01,int,31,30,3.4,小节,日期,xx 来源: https://blog.csdn.net/ling_X_super/article/details/113934021