总时间限制:
1000ms
内存限制:
65536kB
描述
给定两个日期,计算相差的天数。比如2010-1-1和2010-1-3相差2天。
输入
共两行:
第一行包含三个整数startYear,startMonth,startDay,分别是起始年、月、日。
第二行包含三个整数endYear,endMonth,endDay,分别是结束年、月、日。
相邻两个整数之间用单个空格隔开。
年份范围在1~3000。保证日期正确且结束日期不早于起始日期。
输出
输出一个整数,即是两个日期相差的天数。
样例输入
2008 1 1 2009 1 1
样例输出
366
这个题目没有什么好说的,因为所有的天数不会超过int,所以直接模拟每个年份,加起来所有的天数就可以了,
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int sy,sm,sd;
int ey,em,ed;
int sum=0,sum1=0;
cin>>sy>>sm>>sd;
cin>>ey>>em>>ed;
for(int i=1;i<sy;i++)
{
sum+=365;
if(i%4==0&&i%100!=0||i%400==0)
sum++;
}
for(int i=1;i<sm;i++)
{
sum+=a[i];
if(i==2&&(sy%4==0&&sy%100!=0||sy%400==0))
sum++;
}
sum+=sd;
for(int i=1;i<ey;i++)
{
sum1+=365;
if(i%4==0&&i%100!=0||i%400==0)
sum1++;
}
for(int i=1;i<em;i++)
{
sum1+=a[i];
if(i==2&&(ey%4==0&&ey%100!=0||ey%400==0))
sum1++;
}
sum1+=ed;
cout<<sum1-sum<<endl;
return 0;
}