A - 18岁生日
2017-07-06 21:46
169 查看
A - 18岁生日
Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u
Submit Status Practice HDU
1201
Description
Gardon的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达1
4000
8岁生日所经过的总天数,让他好来比较一下。
Input
一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
Output
T行,每行一个数,表示此人从出生到18岁生日所经过的天数。如果这个人没有18岁生日,就输出-1。
Sample Input
1
1988-03-07
Sample Output
6574 这个是日期处理的经典。用暴力法会超时,只能用简便计算。算出总的时间,然后再减去一些运年的一天数,根据时间的数来判断见还是加。注意全据的数组不要写错。。、
Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u
Submit Status Practice HDU
1201
Description
Gardon的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达1
4000
8岁生日所经过的总天数,让他好来比较一下。
Input
一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
Output
T行,每行一个数,表示此人从出生到18岁生日所经过的天数。如果这个人没有18岁生日,就输出-1。
Sample Input
1
1988-03-07
Sample Output
6574 这个是日期处理的经典。用暴力法会超时,只能用简便计算。算出总的时间,然后再减去一些运年的一天数,根据时间的数来判断见还是加。注意全据的数组不要写错。。、
#include<stdio.h> int month[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}}; bool panduan(int n) { if((n%4==0&&n%100!=0)||(n%400==0)) return 1; else return 0; } int main() { int year,yue,ri; int T; scanf("%d",&T); while(T--) { scanf("%d-%d-%d",&year,&yue,&ri); int sum; if(yue==2&&ri==29) printf("-1\n"); else {sum=18*365; for(int i=0;i<=18;i++) { if(panduan(i+year)==1) sum++; } if(panduan(year)==1&&yue>2) sum--; if(panduan(year+18)==1&&yue<3&&ri!=29) sum--; printf("%d\n",sum); } } }
相关文章推荐
- 杭电ACM--HDU1201--18岁生日
- 18岁生日
- HDU 1201-18岁生日(字符串)
- HDU 1201 18岁生日
- 18岁生日
- HDU--1201 -- 18岁生日 [水] [日期计算]
- HDU 1201 18岁生日
- hdoj18岁的生日
- HDOJ-1201 18岁生日
- hdoj-1201 18岁生日【日期和时间处理】
- hdoj--1201--18岁生日(模拟)
- hdoj 1201 (+基础练习一)18岁生日
- 杭电ACM 1201 18岁生日
- 88.hdu--1201--18岁生日
- HDU1201 18岁生日【日期计算+水题】
- 杭电1201_18岁生日
- 杭电 OJ 1201 18岁生日
- 阿里巴巴18岁生日再提三大战略 这次与以往有何不同?
- HDOJ 1201 18岁生日
- 【HDU】1201 18岁生日