본문 바로가기
Algorythms

백준 1308번 D-Day java 풀이

by 준형코딩 2024. 1. 17.

문제

캠프에 오게 된 송유진은 캠프가 너무 지루해서 오늘로부터 캠프가 끝날 때 까지 며칠이나 남았는지 알아보고 싶었다. 그런데 캠프는 비상식적으로 길지도 몰라서 (윤년을 포함할지도 모른다) 손으로 하나하나 세기에는 힘들어 보였다.

더욱 정확한 계산을 위해, 유진이는 윤년이 정해지는 기준을 찾아보았고, 그것은 다음과 같았다.

  • 서력기원 연수가 4로 나누어떨어지는 해는 우선 윤년으로 한다. (2004년, 2008년, …)
  • 100으로 나누어떨어지는 해는 평년으로 한다. (2100년, 2200년, …)
  • 400으로 나누어떨어지는 해는 다시 윤년으로 한다. (1600년, 2000년, …)

그런데 캠프가 너무 길 경우, 사춘기인 유진이는 캠프에 무단으로 빠질지도 모른다.

입력

첫째 줄에 오늘의 날짜가 주어지고, 두 번째 줄에 D-Day인 날의 날짜가 주어진다. 날짜는 연도, 월, 일순으로 주어지며, 공백으로 구분한다. 입력 범위는 1년 1월 1일부터 9999년 12월 31일 까지 이다. 오늘의 날짜는 항상 D-Day보다 앞에 있다.

출력

오늘부터 D-Day까지 x일이 남았다면, "D-"를 출력하고 그 뒤에 공백 없이 x를 출력한다. 만약 캠프가 천년 이상 지속된다면 (오늘이 y년 m월 d일이고, D-Day가 y+1000년 m월 d일과 같거나 늦다면) 대신 "gg"를 출력한다. 오늘이 2월 29일인 경우는 주어지지 않는다.

예제 입력 1 복사

2008 12 27
2009 1 22

예제 출력 1 복사

D-26

 

 

평년과 윤년에 대한 개념을 알게 해 준 문제

 

평년 = 2월 28일까지

윤년 = 2월 29일까지

 

나머지 달은 고정

 

- java 풀이 (참고 : https://velog.io/@digh0515/%EB%B0%B1%EC%A4%80-1308%EB%B2%88D-Day)

import java.io.*;
import java.util.*;
import java.util.stream.Collectors;


public class Main {


    static int h, y;


    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
//        StringTokenizer st = new StringTokenizer(br.readLine());

        Scanner sc = new Scanner(System.in);

        int Tyear = sc.nextInt();
        int Tmonth = sc.nextInt();
        int Tday = sc.nextInt();

        int Dyear = sc.nextInt();
        int Dmonth = sc.nextInt();
        int Dday = sc.nextInt();

        if ((Dyear - Tyear > 1000) || (Dyear - Tyear == 1000 && Dmonth > Tmonth) || (Dyear - Tyear == 1000
                && Dmonth == Tmonth && Dday >= Tday)) {
            System.out.println("gg");
        } else {
            long T_findingdays = FindingDays(Tyear, Tmonth, Tday);
            long D_findingdays = FindingDays(Dyear, Dmonth, Dday);
            System.out.println("D-" + (D_findingdays - T_findingdays));
        }


    }

    private static long FindingDays(int year, int month, int day) {
        long days = 0;
        int[] date;
        for (int i = 1; i < year; i++) {
            date = dayArray(i);
            for (int j = 0; j < 12; j++) {
                days += date[j];
            }
        }
        date = dayArray(year);
        for (int i = 0; i < month - 1; i++) {
            days += date[i];
        }
        days += day;
        return days;
    }

    private static int[] dayArray(int year) {
        int[] day = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
        if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) {
            day[1] = 29;
        }
        return day;

    }


}