算法笔记(入门篇1-入门模拟)--日期处理--问题 D: 日期类

问题 D: 日期类

时间限制: 1 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<stdio.h>
int month[13][2]= {{0,0},
    {31,31},
    {28,29},
    {31,31},
    {30,30},
    {31,31},
    {30,30},
    {31,31},
    {31,31},
    {30,30},
    {31,31},
    {30,30},
    {31,31}
};
bool isLeap(int year)
{
    return (year%4==0&&year%100!=0)||(year%400==0);
}
int main()
{
    int time1,y1,m1,d1;
    int m;
    while(scanf("%d",&m)!=EOF)
    {
        while(m--)
        {
            scanf("%d%d%d",&y1,&m1,&d1);
            if(d1+1>month[m1][isLeap(y1)])
            {
                m1++;
                d1=1;
            }
            else
            {
                d1=d1+1;
            }
            if(m1==13)
            {
                y1++;
                m1=1;
            }
            printf("%.4d-%.2d-%.2d\n",y1,m1,d1);
        }
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/syd1091245120/article/details/81415582