算法笔记练习 3.4 日期处理 问题 D: 日期类

算法笔记练习 题解合集

本题链接

题目

题目描述
编写一个日期类,要求按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 
int main() {
	int T;
	scanf("%d", &T);
	while (T--) {
		int y, m, d;
		scanf("%d %d %d", &y, &m, &d);
		if ((m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10) && d == 31) {
			d = 1;
			m++;
		} else if (m == 12 && d == 31) {
			d = 1;
			m = 1;
			y++;
		} else if ((m == 4||m == 6||m == 9||m == 11) && d == 30) {
			d = 1;
			m++;
		} else if (m == 2 && d == 28) {
			d = 1;
			m++;
		} else {
			d++;
		}
		printf("%04d-%02d-%02d\n", y, m, d);
	} 
	return 0;
} 

你可能感兴趣的:(算法笔记)