알고리즘

[프로그래머스] - PCCP 기출문제 1

예림밈 2025. 4. 25. 16:12

문제

당신은 동영상 재생기를 만들고 있습니다. 당신의 동영상 재생기는 10초 전으로 이동, 10초 후로 이동, 오프닝 건너뛰기 3가지 기능을 지원합니다. 각 기능이 수행하는 작업은 다음과 같습니다. 10초 전으로 이동: 사용자가 "prev" 명령을 입력할 경우 동영상의 재생 위치를 현재 위치에서 10초 전으로 이동합니다. 현재 위치가 10초 미만인 경우 영상의 처음 위치로 이동합니다. 영상의 처음 위치는 0분 0초입니다. 10초 후로 이동: 사용자가 "next" 명령을 입력할 경우 동영상의 재생 위치를 현재 위치에서 10초 후로 이동합니다. 동영상의 남은 시간이 10초 미만일 경우 영상의 마지막 위치로 이동합니다. 영상의 마지막 위치는 동영상의 길이와 같습니다.
오프닝 건너뛰기: 현재 재생 위치가 오프닝 구간(op_start ≤ 현재 재생 위치 ≤ op_end)인 경우 자동으로 오프닝이 끝나는 위치로 이동합니다.
동영상의 길이를 나타내는 문자열 video_len, 기능이 수행되기 직전의 재생위치를 나타내는 문자열 pos, 오프닝 시작 시각을 나타내는 문자열 op_start, 오프닝이 끝나는 시각을 나타내는 문자열 op_end, 사용자의 입력을 나타내는 1차원 문자열 배열 commands가 매개변수로 주어집니다. 이때 사용자의 입력이 모두 끝난 후 동영상의 위치를 "mm:ss" 형식으로 return 하도록 solution 함수를 완성해 주세요.

 

코드

class Solution {
    public String solution(String video_len, String pos,
                           String op_start, String op_end, String[] commands) {
        // 비디오 길이와 현재 위치를 분과 초로 변환
        String[] first = pos.split(":");
        int mm = Integer.parseInt(first[0]);  // 분
        int ss = Integer.parseInt(first[1]);  // 초
        
        String[] parts = video_len.split(":");
        int video_mm = Integer.parseInt(parts[0]);  // 비디오 길이(분)
        int video_ss = Integer.parseInt(parts[1]);  // 비디오 길이(초)
        
        String[] op_starts = op_start.split(":");
        String[] op_ends = op_end.split(":");
        int start_mm = Integer.parseInt(op_starts[0]);  // 오프닝 시작(분)
        int start_ss = Integer.parseInt(op_starts[1]);  // 오프닝 시작(초)
        int end_mm = Integer.parseInt(op_ends[0]);    // 오프닝 끝(분)
        int end_ss = Integer.parseInt(op_ends[1]);    // 오프닝 끝(초)
        
        // 오프닝 구간을 건너뛰기
        if ((mm > start_mm || (mm == start_mm && ss >= start_ss)) &&
            (mm < end_mm || (mm == end_mm && ss < end_ss))) {
            mm = end_mm;
            ss = end_ss;
        }
        
        // 명령 처리
        for (String command : commands) {
            if (command.equals("prev")) {  // 10초 전으로 이동
                ss -= 10;
                if (ss < 0) {
                    mm -= 1;
                    ss = 60 + ss;
                }
                if (mm < 0) {  // 0초 미만일 경우 0분 0초로 설정
                    mm = 0;
                    ss = 0;
                }
            } else if (command.equals("next")) {  // 10초 후로 이동
                ss += 10;
                if (ss >= 60) {
                    mm += ss / 60;
                    ss = ss % 60;
                }
                if (mm > video_mm || (mm == video_mm && ss > video_ss)) {
                    mm = video_mm;
                    ss = video_ss;  // 비디오 끝으로 이동
                }
            }
            
            // 오프닝 구간을 건너뛰기 (매 명령 후 체크)
            if ((mm > start_mm || (mm == start_mm && ss >= start_ss)) &&
                (mm < end_mm || (mm == end_mm && ss < end_ss))) {
                mm = end_mm;
                ss = end_ss;
            }
        }
        
        // 결과를 "mm:ss" 형식으로 반환
        return String.format("%02d:%02d", mm, ss);
    }
}

아직 자바에 익숙하지 않아서 코드가 너무 복잡(?)해 보이는 것 같다ㅜㅜ


문제 출처
https://school.programmers.co.kr/learn/courses/30/lessons/340213#

'알고리즘' 카테고리의 다른 글

[Softeer] - 성적 평균  (0) 2025.04.25
[프로그래머스] -PCCE 기출문제 9번 / 지폐 접기  (4) 2025.04.25
[백준]- 9086번  (0) 2025.04.25
[백준] - 10810번  (0) 2025.04.25
[백준] - 2480번  (0) 2025.04.25