《算法笔记》3.4小节—日期处理 问题 D: 日期类
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了《算法笔记》3.4小节—日期处理 问题 D: 日期类,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含844字,纯文字阅读大概需要2分钟。
内容图文
![《算法笔记》3.4小节—日期处理 问题 D: 日期类](/upload/InfoBanner/zyjiaocheng/603/7b9957e10a144a229f2114c42b1c233f.jpg)
问题 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);
}
}
}
}
内容总结
以上是互联网集市为您收集整理的《算法笔记》3.4小节—日期处理 问题 D: 日期类全部内容,希望文章能够帮你解决《算法笔记》3.4小节—日期处理 问题 D: 日期类所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。