题目描述:
给出年份m和一年中的第n天,算出第n天是几月几号。
输入:
输入包括两个整数:y和n。
输出:
可能有多组测试数据,对于每组数据,按格式yyyy-mm-dd将输入中对应的日期打印出来。
样例输入:
2000 3
2000 31
2000 40
2000 60
2000 61
2001 60
样例输出:
2000-1-03
2000-01-31
2000-02-09
2000-02-29
2000-03-01
2001-03-01
自己写的代码:
#include <iostream>
#include <cstdio>
using namespace std;
int daytab[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;
int days;
int i;
while (scanf("%d%d", &year, &days) != EOF) {
int row = isleapyear(year);
for (i = 1; i <= 12; i++) {
if (days <= daytab[row][i]) {
break;
} else {
days = days - daytab[row][i];
}
}
printf("%04d-%02d-%02d\n", year, i, days);
}
return 0;
}
已测试通过:
王道书上的代码:
#include <iostream>
#include <cstdio>
using namespace std;
int daytab[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;
while (scanf("%d%d", &year, &number) != EOF) {
month = 0;
int row = isleapyear(year);
while (number > daytab[row][month]) {
number = number - daytab[row][month];
month++;
}
day = number;
printf("%04d-%02d-%02d\n", year, month, day);
}
return 0;
}