HDOJ 1201

简介: 18岁生日 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 10076 Accepted Submission(s): 3201 Problem Description Gardon的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达18岁生日所经过的总天数,让他好来比较一下。

18岁生日

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 10076 Accepted Submission(s): 3201


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
 
 
/*
如果出生在2月29号,那么也就说出生那一年一定是闰年,通过简单证明可得:闰年+18=非闰年
*/
#include <iostream>
using namespace std;
bool is_leap(int n)
{
	if((n%4==0 && n%100!=0) || n%400==0)
		return 1;
	else
		return 0;
}
int main()
{
	int T;int year, month, day;int run=0;
	char tmp;
	scanf("%d", &T);
	while(T--)
	{
		run=0;
		// 先开始我还傻傻的去用string表示...麻烦...
		cin >> year >> tmp >> month >> tmp >> day;
		if(month==2 && day==29)
		{
			cout << -1 << endl;
			continue;
		}
		if(month>=3)
		{
			for(int i=1; i<=18; ++i)
				if(is_leap(year+i))
					run++;
		}
		else
		{
			for(int i=1; i<=18; ++i)
				if(	is_leap(year+i-1))
					run++;
		}
		cout << 365*18+run << endl;
	}
	return 0;
}

 

目录
相关文章
HDOJ 2075 A|B?
HDOJ 2075 A|B?
63 0
HDOJ 1303 Doubles(简单题)
HDOJ 1303 Doubles(简单题)
79 0
HDOJ 2004 成绩转换
HDOJ 2004 成绩转换
68 0
HDOJ 2019 数列有序!
HDOJ 2019 数列有序!
87 0
|
安全
HDOJ 2022 海选女主角
HDOJ 2022 海选女主角
129 0
HDOJ 1323 Perfection(简单题)
Problem Description From the article Number Theory in the 1994 Microsoft Encarta: “If a, b, c are integers such that a = bc, a is called a...
817 0
HDOJ 1214 圆桌会议
Problem Description HDU ACM集训队的队员在暑假集训时经常要讨论自己在做题中遇到的问题.每当面临自己解决不了的问题时,他们就会围坐在一张圆形的桌子旁进行交流,经过大家的讨论后一般没有解决不了的问题,这也只有HDU ACM集训队特有的圆桌会议,有一天你也...
780 0
HDOJ 2013 蟠桃记
Problem Description 喜欢西游记的同学肯定都知道悟空偷吃蟠桃的故事,你们一定都觉得这猴子太闹腾了,其实你们是有所不知:悟空是在研究一个数学问题! 什么问题?他研究的问题是蟠桃一共有多少个! 不过,到最后,他还是没能解决这个难题,呵呵^-^ 当时的情况是这样的: 第一天悟空吃掉桃子总数一半多一个,第二天又将剩下的桃子吃掉一半多一个,以后每天吃掉前一天剩下的一半多一个,到第n天准备吃的时候只剩下一个桃子。
1047 0
|
存储 Java
HDOJ 2602
Bone Collector Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 14134    Accepted Submission(s...
920 0
|
Java
HDOJ 1234
开门人和关门人 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 7142    Accepted Submission(s): 3656 Problem Description 每天第一个到机房的人要把门打开,最后一个离开的人要把门关好。
767 0