18岁生日
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 21864 Accepted Submission(s): 6933
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
Author
Gardon
Source
Recommend
当红色的Accpted出现在我面前的时候,我几乎泪流满面,真的,即使今天是愚人节,但是这是我的实话.....即使它是一个大水果,妈蛋!我也足足a了1个小时,一个小时......各位a友,AC且不易,且行且珍惜啊。
按照一般c/c++的思路,这题因该就是用格式化输入scanf("%d-%d-%d",year,month,day),然后又是用闰年平年搞一搞,然后考虑没有18岁的生日这种情况,就是if(month==2&&day==29){ printf("-1"); continue }.我开头也是这样想的,但是决定认真学Java的我,想用Java来ac这道大水果,然后光是格式化输入年月日,就弄得不行,但是有一点被我发现,就是Java的封装Calendar类真是好用,我只需要直接调用就可以了,但是因为不熟悉用法,走了不少弯路,浪费了不少时间......不过总之我认为我的方法还算比较创新的,闰年平年什么的,我根本就不需要管!
import java.io.*;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
public class Main
{
public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
int n = input.nextInt(); //数T,T行每行有一个日期
input.nextLine();
for (int i = 0; i < n; i++)
{
String time = input.nextLine(); //读入日期保存在字符串time变量里
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
if (n == 0)
break;
try
{
Date date1 = sdf.parse(time); //time转换为Date类型
Date date2 = new Date(); //初始化date2用来保存18年后日期
Calendar cal1 = Calendar.getInstance(); //初始化cal1用来保存初始日期
Calendar cal2 = Calendar.getInstance(); //初始化cal2用来保存18年后日期
cal1.setTime(date1);
cal2.setTime(date1);
cal2.add(Calendar.YEAR, 18); //加上18年后的cal2
date2 = cal2.getTime();
long day1 = (long) date1.getTime() / (1000 * 60 * 60 * 24); //算初始日期的总天数
long day2 = (long) date2.getTime() / (1000 * 60 * 60 * 24); //算18年后的总天数
if (cal1.get(Calendar.MONTH) + 1 == 2 //Calendar.MONTH 月份是从0开始的,所以要加1
&& cal1.get(Calendar.DATE) == 29) //Calendar.DATE 即是日
{
System.out.println("-1");
}
else
{
System.out.println(day2 - day1); //相减便是过去的天数!
}
}
catch (ParseException e)
{
System.out.println("输入失败!");
e.printStackTrace();
}
}
}
}