HDOJ 1201 18岁生日

简介: Problem Description Gardon的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达18岁生日所经过的总天数,让他好来比较一下。

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

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int t = sc.nextInt();
        while(t-->0){
            String str = sc.next();
            String[] num = str.split("-");
            int[] number = new int[3];
            for(int i=0;i<num.length;i++){
                number[i] = Integer.valueOf(num[i]);
            }
            int day=0;
            if(isRun(number[0])&&number[1]==2&&number[2]==29&&!isRun(number[0]+18)){
                System.out.println(-1);
                continue;
            }//出生的时候是闰年,2月29生,且18岁时候不是闰年,无生日。
            if(number[1]<3){
                for(int i=0;i<18;i++){
                    if(isRun(number[0]+i)){
                        day+=366;
                    }else{
                        day+=365;
                    }
                }
            }else{
                for(int i=1;i<=18;i++){
                    if(isRun(number[0]+i)){
                        day+=366;
                    }else{
                        day+=365;
                    }
                }
            }


            System.out.println(day);


        }


    }

    private static boolean isRun(int i) {
        if((i%4==0&&i%100!=0)||(i%400==0)){
            return true;
        }
        return false;
    }

}
目录
相关文章
HDOJ 2046 骨牌铺方格
HDOJ 2046 骨牌铺方格
125 0
HDOJ 2046 骨牌铺方格
|
Java 数据安全/隐私保护
HDOJ 2100 Lovekey
HDOJ 2100 Lovekey
78 0
HDOJ 2057 A + B Again
HDOJ 2057 A + B Again
85 0
HDOJ 2075 A|B?
HDOJ 2075 A|B?
64 0
|
机器学习/深度学习
HDOJ 2074 叠筐
HDOJ 2074 叠筐
99 0
HDOJ 2034 人见人爱A-B
HDOJ 2034 人见人爱A-B
111 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...
822 0
HDOJ 2041 超级楼梯
Problem Description 有一楼梯共M级,刚开始时你在第一级,若每次只能跨上一级或二级,要走上第M级,共有多少种走法? Input 输入数据首先包含一个整数N,表示测试实例的个数,然后是N行数据,每行包含一个整数M(1
539 0