프로그래머스
SW개발자를 위한 평가, 교육의 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
PCCP 기출문제[PCCP 기출문제] 1번 / 동영상 재생기
문제설명
당신은 동영상 재생기를 만들고 있습니다. 당신의 동영상 재생기는 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" |
코드
import java.util.Arrays;
import java.util.Map;
import java.util.HashMap;
class Solution {
public String solution(String video_len, String pos, String op_start, String op_end, String[] commands) {
return videoPlayer(video_len, pos, op_start, op_end, commands);
}
/**
* 동영상의 위치를 조정해 "mm:ss" 포맷으로 return
* @param video_len 동영상의 길이를 나타내는 문자열
* @param pos 기능이 수행되기 직전의 재생위치를 나타내는 문자열
* @param op_start 오프닝 시작 시각을 나타내는 문자열
* @param op_end 오프닝이 끝나는 시각을 나타내는 문자열
* @param commands 사용자의 입력을 나타내는 1차원 문자열 배열
* @return 사용자의 입력이 모두 끝난 후 동영상의 위치 "mm:ss" 포맷
*/
public String videoPlayer(String video_len, String pos, String op_start, String op_end, String[] commands) Map<String, String> strTimeMap = new HashMap<>( strTimeMap.put("video_len", video_len strTimeMap.put("pos", pos strTimeMap.put("op_start", op_start strTimeMap.put("op_end", op_end Map<String, Integer> intTimeMap = toIntegerTime(strTimeMap);
Arrays
.asList(commands)
.forEach(el -> {
intTimeMap.put("pos", skip(intTimeMap).get("pos"));
if ("prev".equals(el)) {
int time = intTimeMap.get("pos")-10 > 0 ? intTimeMap.get("pos")-10 : 0;
intTimeMap.put("pos", time);
}
else {
int time = intTimeMap.get("pos")+10 > intTimeMap.get("video_len") ? intTimeMap.get("video_len") : intTimeMap.get("pos")+10;
intTimeMap.put("pos", time);
}
});
intTimeMap.put("pos", skip(intTimeMap).get("pos"));
return toStringTime(intTimeMap).get("pos");
}
/**
* hh:mm 포맷으로 받은 String타입의 시간을 int타입의 분으로 계산해 map에 put
* @param strTimeMap hh:mm 포맷의 String타입의 시간 Map
* @return int타입의 분으로 계산한 시간 Map
*/
public Map<String, Integer> toIntegerTime(Map<String, String> strTimeMap) {
Map<String, Integer> intTimeMap = new HashMap<>();
strTimeMap.forEach((key, value) -> {
int time = Integer.parseInt(value.split("[:]")[0])*60
+ Integer.parseInt(value.split("[:]")[1]);
intTimeMap.put(key, time);
});
return intTimeMap;
}
/**
* int타입의 분을 hh:mm 포맷의 String타입으로 계산해 map에 put
* @param intTimeMap int타입의 분으로 계산한 시간 Map
* @return hh:mm 포맷의 String타입의 시간 Map
*/
public Map<String, String> toStringTime(Map<String, Integer> intTimeMap) {
Map<String, String> strTimeMap = new HashMap<>();
intTimeMap.forEach((key, value) -> {
String hh = Integer.toString(intTimeMap.get(key)/60);
hh = hh.length() == 1 ? "0"+hh : hh;
String mm = Integer.toString(intTimeMap.get(key)%60);
mm = mm.length() == 1 ? "0"+mm : mm;
strTimeMap.put(key, hh+":"+mm);
});
return strTimeMap;
}
/**
* 재생위치{@link pos}의 위치가 오프닝 구간인지 체크
* @param intTimeMap int타입의 분으로 계산한 시간 Map
* @return int타입의 분으로 계산한 시간 Map
*/
public Map<String, Integer> skip(Map<String, Integer> intTimeMap) {
int skip =
intTimeMap.get("pos") < intTimeMap.get("op_start") ? intTimeMap.get("pos")
: intTimeMap.get("pos") > intTimeMap.get("op_end") ? intTimeMap.get("pos")
: intTimeMap.get("op_end");
intTimeMap.put("pos", skip);
return intTimeMap;
}
}
결과

'코딩테스트' 카테고리의 다른 글
| [프로그래머스/자바] 완전탐색 > 카펫 (0) | 2025.10.02 |
|---|---|
| [프로그래머스/자바] 연습문제 > 최솟값 만들기 (0) | 2025.09.30 |
| [프로그래머스/자바] 2025 프로그래머스 코드챌린지 1차 예선 > 유연근무제 (1) | 2025.07.22 |
| [프로그래머스/자바] 2025 프로그래머스 코드챌린지 2차 예선 > 택배 상자 꺼내기 (1) | 2025.07.18 |
| [코테/Java] 프로그래머스 : 뒤에 있는 큰 수 (0) | 2023.08.26 |
댓글