題目:
給出年分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
我的思路
//給出天數,算出年月日
#include <stdio.h>
#define ISYEAP(x) (x % 4 == 0 && x % 100 != 0 || x % 400 == 0 ? 1 : 0)
int dayOfMonth[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
};
struct Date
{
int Day;
int Month;
int Year;
void nextDay()
{
Day++;
if(Day > dayOfMonth[Month][ISYEAP(Year)])
{
Day = 1;
Month++;
if(Month > 12)
{
Month = 1;
Year++;
}
}
}
};
int buf[3001][13][32];
int main()
{
Date tmp;
tmp.Day = 1;
tmp.Month = 1;
tmp.Year = 0;
int cnt = 0;
while(tmp.Year != 3001)
{
buf[tmp.Year][tmp.Month][tmp.Day] = cnt;
cnt++;
tmp.nextDay();
}
int y, days;
while(scanf("%d%d", &y, &days) != EOF)
{
for(int m = 1; m <= 12; m++)
{
if(dayOfMonth[m][ISYEAP(y)] < days)
{
days -= dayOfMonth[m][ISYEAP(y)];
}
else
{
printf("%d-%02d-%02d\n", y, m, days); //這個控制格式
break;
}
}
}
return 0;
}