编程语言
首页 > 编程语言> > 《算法笔记》3.4小节—日期处理 问题 D: 日期类

《算法笔记》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