ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

《算法笔记》3.4小节—日期处理 问题 D: 日期类

2021-02-22 12:33:52  阅读:145  来源: 互联网

标签:01 int 31 30 3.4 小节 日期 xx


问题 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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有