SWEA 13229 일요일
문제 정보
- 문제 출처 : SW Expert Academy
- 문제 번호 : 13229
- 문제 제목 : 일요일
- 문제 난이도 : D3
- 풀이 언어 : Java
문제
오늘의 요일을 나타내는 문자열 S가 주어진다. S는 “MON”(월), “TUE”(화), “WED”(수), “THU”(목), “FRI”(금), “SAT”(토), “SUN”(일) 중 하나이다. 다음 (즉, 내일 이후의 가장 빠른) 일요일까지는 며칠 남았을까?
접근
HashMap 을 사용하여 문제를 풀었다.
풀이
- Scanner 객체를 사용하여 입력을 처리합니다.
- 첫 번째 줄에서 테스트 케이스의 수 T를 읽습니다.
- HashMap을 사용하여 요일 문자열을 인덱스로 매핑합니다. 예를 들어, “MON”은 0에 매핑됩니다.
- 요일 인덱스를 사용하여 다음 일요일까지 남은 일수를 저장하는 배열 daysUntilSunday를 정의합니다.
- 각 테스트 케이스에 대해 입력된 요일 문자열을 읽습니다.
- 해당 요일의 인덱스를 dayMap에서 찾습니다.
- daysUntilSunday 배열을 사용하여 해당 요일부터 다음 일요일까지 남은 일수를 계산합니다.
- 결과를 형식에 맞게 출력합니다.
후기
비슷한 유형의 문제를 더 풀어볼 계획이다.
코드
Java
import java.util.Scanner;
import java.io.FileInputStream;
import java.util.HashMap;
class Solution
{
public static void main(String args[]) throws Exception
{
Scanner sc = new Scanner(System.in);
int T;
T=sc.nextInt();
int[] daysUntilSunday = {6, 5, 4, 3, 2, 1, 7};
HashMap<String, Integer> dayMap = new HashMap<>();
dayMap.put("MON", 0);
dayMap.put("TUE", 1);
dayMap.put("WED", 2);
dayMap.put("THU", 3);
dayMap.put("FRI", 4);
dayMap.put("SAT", 5);
dayMap.put("SUN", 6);
for(int test_case = 1; test_case <= T; test_case++)
{
String day = sc.next();
int dayIndex = dayMap.get(day);
int result = daysUntilSunday[dayIndex];
System.out.println("#" + test_case + " " + result);
}
}
}
Java