题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1201
18岁生日
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 20031 Accepted Submission(s): 6336
Problem Description
Gardon的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达18岁生日所经过的总天数,让他好来比较一下。
Input
一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
Output
T行,每行一个数,表示此人从出生到18岁生日所经过的天数。如果这个人没有18岁生日,就输出-1。
Sample Input
1 1988-03-07
Sample Output
6574
模拟整个过程即可,只有一种特殊情况,那就是month=2,day=29,由于今年如果是闰年,那18年后势必不是闰年。
1.先算出今天到年底的天数
2.再算出明年到第17年末所经过的天数
3.最后算出从第18年初到month月day天的日子数即可。
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<sstream>
#include<vector>
#include<map>
#include<stack>
#include<list>
#include<set>
#include<queue>
#define LL long long
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1 | 1
using namespace std;
const int maxn=1005,maxe=100005,inf=1<<29;
int n,m;
int v[2][12]={
{31,28,31,30,31,30,31,31,30,31,30,31},
{31,29,31,30,31,30,31,31,30,31,30,31}
};
int judge(int n)
{
if(n%400==0||(n%100!=0&&n%4==0)) return 1;
return 0;
}
int main()
{
int year,month,day,t;
scanf("%d",&t);
while(t--)
{
scanf("%d-%d-%d",&year,&month,&day);
if(month==2&&day==29) {printf("-1\n");continue;}//特判
int sum=0;
int f=judge(year);
sum+=v[f][month-1]-day;//计算出今天据月末的天数
for(int i=month;i<12;i++) sum+=v[f][i];//计算出第二月到年末的天数
for(int i=year+1;i<year+18;i++)//计算出第二年到第17年末的天数
if(judge(i)) sum+=366;
else sum+=365;
f=judge(year+18);
for(int i=0;i<month-1;i++) sum+=v[f][i];//第18年初到第month月的天数
sum+=day;
printf("%d\n",sum);
}
return 0;
}