1924번: 2007년
첫째 줄에 빈 칸을 사이에 두고 x(1 ≤ x ≤ 12)와 y(1 ≤ y ≤ 31)이 주어진다. 참고로 2007년에는 1, 3, 5, 7, 8, 10, 12월은 31일까지, 4, 6, 9, 11월은 30일까지, 2월은 28일까지 있다.
www.acmicpc.net
문제
오늘은 2007년 1월 1일 월요일이다. 그렇다면 2007년 x월 y일은 무슨 요일일까? 이를 알아내는 프로그램을 작성하시오.
입력
첫째 줄에 빈 칸을 사이에 두고 x(1 ≤ x ≤ 12)와 y(1 ≤ y ≤ 31)이 주어진다. 참고로 2007년에는 1, 3, 5, 7, 8, 10, 12월은 31일까지, 4, 6, 9, 11월은 30일까지, 2월은 28일까지 있다.
출력
첫째 줄에 x월 y일이 무슨 요일인지에 따라 SUN, MON, TUE, WED, THU, FRI, SAT중 하나를 출력한다.
예제 입력 1
1 1
예제 출력 1
MON
예제 입력 2
3 14
예제 출력 2
WED
예제 입력 3
9 2
예제 출력 3
SUN
예제 입력 4
12 25
예제 출력 4
TUE
풀이 .
import java.util.*;
import java.io.*;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st = new StringTokenizer(br.readLine());
int x = Integer.parseInt(st.nextToken());
int y = Integer.parseInt(st.nextToken());
int[] months = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
String[] days = {"SUN", "MON", "TUE", "WED", "THU", "FRI", "SAT"};
int sum = 0;
for(int i = 0; i < x - 1; i++) {
sum += months[i];
}
sum += y;
bw.write(days[sum % days.length]);
br.close();
bw.flush();
bw.close();
}
}
1월 1일 부터 오늘까지 며칠이나 지났는지 일 수를 계산 (오늘까지 포함하여)
총 일 수로 나머지 연산을 하여 요일을 구한다.
'알고리즘 문제 > 백준 온라인 저지' 카테고리의 다른 글
[BOJ] 10818 - 최소, 최대 JAVA (0) | 2021.01.09 |
---|---|
[BOJ] 8393 - 합 JAVA (0) | 2021.01.09 |
[BOJ] 2739 - 구구단 JAVA (0) | 2021.01.08 |
[BOJ] 2742 - 기찍 N JAVA (0) | 2021.01.08 |
[BOJ] 2741 - N 찍기 JAVA (0) | 2021.01.08 |