题目
输入年、月、日,计算该天是本年的第几天。
输入描述: 包括三个整数年(1<=Y<=3000)、月(1<=M<=12)、日(1<=D<=31)。
输出描述: 输入可能有多组测试数据,对于每一组测试数据, 输出一个整数,代表Input中的年、月、日对应本年的第几天。
示例1
输入
1990 9 20
2000 5 1
输出
263
122
思路
以1年1月1日作为起始点,打表(某年某月某日到起始点的天数)
计算目标日期和该年1月1日的天数差,差值加1得到今年的第几天
注意点
- 结构体记得要以分号结尾
- 闰年的判断条件(2个)
(year%100!=0 && year%4==0) || (year%400==0)
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
using namespace std;
#define ISYEAP(x) (x%100 != 0 && x%4 == 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 year;
int month;
int day;
void nextDay(){
day++;
if(day > dayOfMonth[month][ISYEAP(year)]){
day = 1;
month ++;
if(month > 12){
month = 1;
year++;
}
}
}
}; //记得分号
int buf[3001][13][32]; //1-3000,1-12,1-31
int main(){
Date tmp;
tmp.year=1;
tmp.month=1;
tmp.day=1;
int cnt=0;
//从1年1月1日开始打表
while(tmp.year!=3001){
buf[tmp.year][tmp.month][tmp.day] = cnt;
tmp.nextDay();
cnt++;
}
int y,m,d;
while(scanf("%d%d%d",&y,&m,&d)!=EOF){
int first = buf[y][1][1];
int target = buf[y][m][d];
cout << target - first + 1 << endl;
}
}