描述
给出年分m和一年中的第n天,算出第n天是几月几号。
输入描述:
输入包括两个整数y(1<=y<=3000),n(1<=n<=366)。
输出描述:
可能有多组测试数据,对于每组数据, 按 yyyy-mm-dd的格式将输入中对应的日期打印出来。
示例1
输入:
2000 3
2000 31
2000 40
2000 60
2000 61
2001 60
输出:
2000-01-03
2000-01-31
2000-02-09
2000-02-29
2000-03-01
2001-03-01
知识点: 暴力求解 模拟 日期问题
解法:
本题是KY19 今年的第几天?的逆命题。
利用while循环,从当年的第一天开始计算nextday。
AC代码:
#include <stdio.h>
int main() {
int y, n;
int monDay[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
int m, d;
while(scanf("%d %d", &y, &n) != EOF) {
if(y % 400 == 0 || y % 100 != 0 && y % 4 == 0)
monDay[2] = 29;
else
monDay[2] = 28;
m = 1;
d = 0;
for(int i = 0; i < n; i++) {
d ++;
if(d > monDay[m]) {
m ++;
d = 1;
}
}
printf("%d-%02d-%02d\n", y, m,d);
}
return 0;
}