九度教程第9题

题目:

给出年分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;
 } 

 

おすすめ

転載: blog.csdn.net/JustinAndy/article/details/104560966