算法笔记3.4C: 打印日期

题目描述


给出年分m和一年中的第n天,算出第n天是几月几号。


输入


输入包括两个整数y(1<=y<=3000),n(1<=n<=366)。


输出


可能有多组测试数据,对于每组数据,按 yyyy-mm-dd的格式将输入中对应的日期打印出来。


样例输入


2013 60
2012 300
2011 350
2000 211


样例输出


2013-03-01
2012-10-26
2011-12-16
2000-07-29


代码

#include<cstdio>

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 y,n;    //y年份n第几天
    int m;      //月份
    int i;      //确定月份循环使用
    while(scanf("%d %d", &y, &n) != EOF){
        m = 1;
        i = 1;
        while(n > month[i][isleap(y)]){
            n -= month[i][isleap(y)];
            m++;
            i++;
        }
        printf("%04d-%02d-%02d\n", y, m, n);
    }
    return 0;
}

总结:解题主要在于利用累加的思想满足这个月的天数则就到了下个月。

新知识点:题目中printf中输出整数一定位数不足数位用0补充,%mnd,用m补充空缺位,n为数据的数位。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值