版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sunlanchang/article/details/88584077
题目描述
输入年、月、日,计算该天是本年的第几天。
输入描述:
包括三个整数年(1<=Y<=3000)、月(1<=M<=12)、日(1<=D<=31)。
输出描述:
输入可能有多组测试数据,对于每一组测试数据,
输出一个整数,代表Input中的年、月、日对应本年的第几天。
示例1
输入
1990 9 20
2000 5 1
输出
263
122
Description
套用日期模板,改一下两个日期差值其中的一个为当年的一月一日。
#include <iostream>
#include <cstdio>
using namespace std;
// 判断闰年
int is_leap(int y)
{
if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0))
return 1;
return 0;
}
int main()
{
// freopen("input.txt", "r", stdin);
int time1, time2, y1, m1, d1, y2, m2, d2;
int months[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};
while (scanf("%d%d%d", &y2, &m2, &d2) != EOF)
{
y1 = y2, m1 = 1, d1 = 1;
int ans = 1;
//计算日期距离的常规思路
while (y1 != y2 || m1 != m2 || d1 != d2)
{
d1++;
if (d1 == months[m1][is_leap(y1)] + 1)
m1 += 1, d1 = 1;
if (m1 == 13)
y1 += 1, m1 = 1;
ans++;
}
printf("%d\n", ans);
}
return 0;
}