Problem Link:点击打开链接
题目描述
有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定他们之间的天数为两天
输入描述:
有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD
输出描述:
每组数据输出一行,即日期差值
输入例子:
20110412 20110422
输出例子:
11
AC code:
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<queue>
#include<set>
#include<map>
#define LL long long
#define PI acos(-1)
#define exp 1e-9
using namespace std;
int mon[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};
int leap(int y)
{
return ((y%4==0&&y%100!=0) || (y%400==0));
}
int day(int y,int m,int d)
{
int id,i,num;
if(!leap(y))
{
id=0;
}
else
{
id=1;
}
num=0;
for(i=1;i<m;++i)
{
num+=mon[i][id];
}
num+=d;
return num;
}
LL num1,num2,ans;
int main()
{
// freopen("D:\\in.txt","r",stdin);
int y1,m1,d1,y2,m2,d2,i;
while(scanf("%4d%2d%2d",&y1,&m1,&d1)!=EOF)
{
scanf("%4d%2d%2d",&y2,&m2,&d2);
num1=num2=0;
for(i=0;i<y1;++i)
{
if(leap(i))
num1+=366;
else
num1+=365;
}
num1+=day(y1,m1,d1);
for(i=0;i<y2;++i)
{
if(leap(i))
num2+=366;
else
num2+=365;
}
num2+=day(y2,m2,d2);
ans=abs(num1-num2)+1;
printf("%lld\n",ans);
}
return 0;
}