SWEA 13229 일요일 D3 (자바 Java)

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

Leave a Comment