九度算法第八题

题目:

输入年、月、日,计算该天是本年的第几天。
输入描述:
包括三个整数年(1<=Y<=3000)、月(1<=M<=12)、日(1<=D<=31)。
输出描述:
输入可能有多组测试数据,对于每一组测试数据,
输出一个整数,代表Input中的年、月、日对应本年的第几天。
示例1
输入
1990 9 20
2000 5 1
输出
263
122
 

我的解法:

#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 d, m, y;
	 while(scanf("%d%d%d", &y, &m, &d) != EOF)
	 {
	 	int days = buf[y][m][d] - buf[y][1][1] + 1;
	 	printf("%d\n", days);
	 }
 	return 0;
 }

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值