문제
캠프에 오게 된 송유진은 캠프가 너무 지루해서 오늘로부터 캠프가 끝날 때 까지 며칠이나 남았는지 알아보고 싶었다. 그런데 캠프는 비상식적으로 길지도 몰라서 (윤년을 포함할지도 모른다) 손으로 하나하나 세기에는 힘들어 보였다.
더욱 정확한 계산을 위해, 유진이는 윤년이 정해지는 기준을 찾아보았고, 그것은 다음과 같았다.
- 서력기원 연수가 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;
}
}
'Algorythms' 카테고리의 다른 글
백준 1940번 주몽 c++ 풀이 (0) | 2024.01.17 |
---|---|
백준 12847번 꿀 아르바이트 c++ 풀이 (0) | 2024.01.17 |
백준 19947번 투자의 귀재 배주형 java 풀이 (0) | 2024.01.17 |
백준 22233번 가희와 키워드 java 풀이 (0) | 2024.01.16 |
백준 13627번 Dangerous Dive c++ 풀이 (0) | 2024.01.11 |