[프로그래머스/level 1] [PCCP 기출문제] 1번 / 동영상 재생기 - 340213

2024. 11. 14. 21:08·코딩 테스트 정복기/프로그래머스
반응형

[level 1] [PCCP 기출문제] 1번 / 동영상 재생기 - 340213

문제 링크

성능 요약

메모리: 78.8 MB, 시간: 24.92 ms

구분

코딩테스트 연습 > PCCP 기출문제

채점결과

정확성: 100.0
합계: 100.0 / 100.0

제출 일자

2024년 11월 13일 05:01:52

문제 설명

당신은 동영상 재생기를 만들고 있습니다. 당신의 동영상 재생기는 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 함수를 완성해 주세요.


제한사항
  • video_len의 길이 = pos의 길이 = op_start의 길이 = op_end의 길이 = 5
    • video_len, pos, op_start, op_end는 "mm:ss" 형식으로 mm분 ss초를 나타냅니다.
    • 0 ≤ mm ≤ 59
    • 0 ≤ ss ≤ 59
    • 분, 초가 한 자리일 경우 0을 붙여 두 자리로 나타냅니다.
    • 비디오의 현재 위치 혹은 오프닝이 끝나는 시각이 동영상의 범위 밖인 경우는 주어지지 않습니다.
    • 오프닝이 시작하는 시각은 항상 오프닝이 끝나는 시각보다 전입니다.
  • 1 ≤ commands의 길이 ≤ 100
    • commands의 원소는 "prev" 혹은 "next"입니다.
    • "prev"는 10초 전으로 이동하는 명령입니다.
    • "next"는 10초 후로 이동하는 명령입니다.

입출력 예
video_len pos op_start op_end commands result
"34:33" "13:00" "00:55" "02:55" ["next", "prev"] "13:00"
"10:55" "00:05" "00:15" "06:55" ["prev", "next", "next"] "06:55"
"07:22" "04:05" "00:15" "04:07" ["next"] "04:17"

입출력 예 설명

입출력 예 #1

  • 시작 위치 13분 0초에서 10초 후로 이동하면 13분 10초입니다.
  • 13분 10초에서 10초 전으로 이동하면 13분 0초입니다.
  • 따라서 "13:00"을 return 하면 됩니다.

입출력 예 #2

  • 시작 위치 0분 5초에서 10초 전으로 이동합니다. 현재 위치가 10초 미만이기 때문에 0분 0초로 이동합니다.
  • 0분 0초에서 10초 후로 이동하면 0분 10초입니다.
  • 0분 10초에서 10초 후로 이동하면 0분 20초입니다. 0분 20초는 오프닝 구간이기 때문에 오프닝이 끝나는 위치인 6분 55초로 이동합니다. 따라서 "06:55"를 return 하면 됩니다.

입출력 예 #3

  • 시작 위치 4분 5초는 오프닝 구간이기 때문에 오프닝이 끝나는 위치인 4분 7초로 이동합니다. 4분 7초에서 10초 후로 이동하면 4분 17초입니다. 따라서 "04:17"을 return 하면 됩니다.

출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges

제출코드

import java.util.*;
class Solution {
    // 자동 건너뛰기 적용
    int[] op_jump(String pos, String op_start, String op_end){
        if(pos.compareTo(op_start)>=0 && op_end.compareTo(pos) >= 0){
            pos = op_end;
        }
        return convert(pos);
    }

    // 00:00 ~ video_len 범위 안으로 조정
    int[] checkRange(int[] pos, String video_len){
        if(pos[0] < 0){
            return new int[] {0,0};
        }
        if(convert(pos).compareTo(video_len) > 0){
            return convert(video_len);
        }
        return pos;
    }


    // 데이터 형식 바꾸기
    String convert(int[] time){
        return (time[0]<10? "0":"")+time[0]+":"+(time[1]<10? "0":"")+time[1];
    }
    int[] convert(String time){
        return Arrays.stream(time.split(":")).mapToInt(Integer::parseInt).toArray();
    }





    public String solution(String video_len, String pos, String op_start, String op_end, String[] commands) {
        // 오프닝 건너뛰기
        int[] curPos = op_jump(pos, op_start, op_end);

        // 사용자 명령어 실행
        for(String c : commands){
            if(c.equals("next")){ // 10초 후로 이동
                if(curPos[1] + 10 >= 60){ 
                    curPos[0]++;
                }
                curPos[1] = (curPos[1] + 10) % 60; 
            }else{ // 10초 전으로 이동
                if(curPos[1] - 10 < 0){
                    curPos[0]--;
                    curPos[1] += 50;
                }else{
                    curPos[1]-= 10;
                }
            }
            // 비디오 범위와 오프닝 건너뛰기 적용
            curPos = checkRange(curPos, video_len);
            curPos = op_jump(convert(curPos), op_start, op_end);
        }


        return convert(curPos);
    }
}
728x90
반응형

'코딩 테스트 정복기 > 프로그래머스' 카테고리의 다른 글

[프로그래머스/level 3] 다단계 칫솔 판매 - 77486  (0) 2024.11.16
[프로그래머스/level 2] 예상 대진표 - 12985  (4) 2024.11.15
[프로그래머스/level 2] 예상 대진표 - 12985  (1) 2024.11.04
[프로그래머스/level 2] 오픈채팅방 - 42888  (0) 2024.11.01
[프로그래머스/level 2] 메뉴 리뉴얼 - 72411  (0) 2024.11.01
'코딩 테스트 정복기/프로그래머스' 카테고리의 다른 글
  • [프로그래머스/level 3] 다단계 칫솔 판매 - 77486
  • [프로그래머스/level 2] 예상 대진표 - 12985
  • [프로그래머스/level 2] 예상 대진표 - 12985
  • [프로그래머스/level 2] 오픈채팅방 - 42888
settong
settong
    250x250
  • settong
    개 발 자 국
    settong
  • 전체
    오늘
    어제
    • 전체보기 (202)
      • Computer Science (50)
        • Network (7)
        • Operating System (18)
        • Data Structure (9)
        • Database (11)
        • Algorithm (5)
      • Language (17)
        • Java (17)
        • Javascript (0)
        • Python (0)
      • Devops (20)
        • AWS (0)
        • Naver Cloud (16)
        • CICD (3)
        • 웹 서버 관리 (1)
      • Front (0)
        • React (0)
      • Backend (5)
        • Spring (5)
      • 코딩 테스트 정복기 (110)
        • 백준 (51)
        • 프로그래머스 (53)
        • 기타 (6)
      • etc (0)
      • 경제 상식 (0)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    프로그래머스
    백트래킹
    백준
    BFS
    분할정복
    Spring Boot
    ncp
    CI/CD
    집합
    lcs
    해시
    ncp202
    다이나믹프로그래밍
    Network
    다익스트라
    DFS
    벨만포드
    완전탐색
    ncp200
    github actions
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
settong
[프로그래머스/level 1] [PCCP 기출문제] 1번 / 동영상 재생기 - 340213
상단으로

티스토리툴바