题解 | #打印日期#

打印日期

https://www.nowcoder.com/practice/b1f7a77416194fd3abd63737cdfcf82b

#include <iostream>
using namespace std;

//将闰年和平年的月份日期存在二维数组数组中
int days[2][13]={
   {0,31,28,31,30,31,30,31,31,30,31,30,31},
   {0,31,29,31,30,31,30,31,31,30,31,30,31}
};

bool IsLeapYear(int year)//判断是不是闰年
{
    return (year%4==0&&year%100!=0)||(year%400==0);
}
int main()
{
    int year,month,day;
    int number=0;
    while(scanf("%d%d",&year,&number)!=EOF)
    {
        month=0;
        int row=IsLeapYear(year);//返回值只可能是1或者是0
        while(number>days[row][month])
        {
            number-=days[row][month];//类减,直到这个天数小于这个月份数循环就结束了
            month++;//减一次月份就进行加加的操作
        }
        day=number;//出了循环那么这个天数就是一个合格的天数了
        printf("%04d-%02d-%02d\n",year,month,day);
    }
    return 0;
}

全部评论

相关推荐

评论
点赞
收藏
分享
牛客网
牛客企业服务