描述
给定两个日期,计算相差的天数。比如2010-1-1和2010-1-3相差2天。
输入
共两行: 第一行包含三个整数startYear,startMonth,startDay,分别是起始年、月、日。
第二行包含三个整数endYear,endMonth,endDay,分别是结束年、月、日。 相邻两个整数之间用单个空格隔开。年份范围在1~3000。保证日期正确且结束日期不早于起始日期。
输出
输出一个整数,即是两个日期相差的天数。
样例输入
2008 1 1
2009 1 1
样例输出
366
提示
闰年被定义为能被4整除的年份,但是能被100整除而不能被400整除的年是例外,它们不是闰年。闰年的2月份有29天。
我的思路:
用for循环计算开始年份和结束年份之间的总天数(包括开始年份的,不包括结束年份的)判断一下 i :闰年加366天,平年加365天, 循环结束之后,把开始年份多算的 减掉,把结束年份没算上的加上。
如果年份相等,同样的思路加减两个月份之间的天数,这样就不包括月份相等的情况,再单独写个if判断月份相等的情况。
C++代码
#include<iostream>
using namespace std;
int main(void){
int sy,sm,sd,ey,em,ed,C=0;
int m[13]={ 0,31,28,31,30,31,30,31,31,30,31,30,31};
cin>>sy>>sm>>sd;
cin>>ey>>em>>ed;
if(ey-sy==0)
{
if((sy%4==0&&sy%100!=0)||(sy%400==0))
m[2]=29;
for(int i=sm;i<em;i++)
{
if(i==sm)
C=m[i]-sd;
else
C+=m[i];
}
C+=ed;
if(sm==em)C=ed-sd;
return C;
}
else{
for(int i=sy;i<ey;i++)
{
if(i%4==0&&i%100!=0||i%400==0)C+=366;
else C+=365;
}
if(sy%4==0&&sy%100!=0||sy%400==0) m[2]=29;
for(int i=1;i<sm;i++) C-=m[i];
C-=sd;
if(ey%4==0&&ey%100!=0||ey%400==0) m[2]=29;
else m[2]=28;
for(int i=1;i<em;i++)C+=m[i];
C+=ed;
return C;
}
return 0;
}