18岁生日
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 36596 Accepted Submission(s): 11845
Problem Description
Gardon的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达18岁生日所经过的总天数,让他好来比较一下。
Input
一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
Output
T行,每行一个数,表示此人从出生到18岁生日所经过的天数。如果这个人没有18岁生日,就输出-1。
Sample Input
11988-03-07
Sample Output
6574
Author
需要注意的是如果出生那年为闰年,且生日是2月29日,那18岁那年必定为平年,2月只有28天。输出-1
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<string.h>
#include<math.h>
using namespace std;
#define fop(a) freopen(a"in.txt","r",stdin),freopen(a"out.txt","w",stdout);
const int days=365;
const int s[]={0,31,28,31,30,31,30,31,31,30,31,30,31};
bool Isleap(int y)
{
if(y%400==0 || y%100 && y%4==0)
return 1;
return 0;
}
int leap(int y)
{
if(!y)
return 0;
return y/4-y/100+y/400;
}
int calc(int day,int mon,int year)
{
int res = (year-1)*days+leap(year-1);
for(int i=1;i<mon;i++)
res+=s[i];
if(Isleap(year)&&mon>2)
res++;
res+=day;
return res;
}
int count_day(int da,int ma,int ya,int db,int mb,int yb)
{
int resa=calc(da,ma,ya);
int resb=calc(db,mb,yb);
return abs(resa-resb);
}
int main()
{
int n,y,m,d;
scanf("%d",&n);
while(n--)
{
scanf("%d-%d-%d",&y,&m,&d);
if(Isleap(y)&&m==2&&d==29)
printf("-1\n");
else
printf("%d\n",count_day(d,m,y+18,d,m,y));
//计算公元元年A和B分别有多少天,然后两个值相减即可。
}
return 0;
}