[동영상 재생기] 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초 후로 이동하는 명령입니다.
입출력 예
입출력 예 설명
입출력 예 #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 하면 됩니다.
[간단설명]
사용자 입력(next, prev) 을 받아, 동영상 현재 재생 위치를 리턴
[접근방법]
1. 동영상 시작 시간, 동영상 종료 시간, 오프닝 시작 시간, 오프닝 종료 시간, 현재 시간을 second 로 계산한다.
2. 동영상 시작 시간 확인, 동영상 종료 시간 확인, 오프닝 시간 확인 함수를 만든다.
3. 사용자 입력이 next 이면 동영상 종료 시간, 오프닝 시간을 확인한다.
4. 사용자 입력이 prev 이면 동영상 사직 시간, 오프닝 시간을 확인한다.
5. second 다시 "mm:ss" 형식으로 리턴한다.
[주의사항]
사용자 입력이 prev 일 때, 한 번 더 오프닝 시간을 확인한다.
[소스공개]
class Solution {
private int op_start_second; //오프닝_시작시간_초
private int op_end_second; //오프닝_종료시간_초
private int video_start_second; //비디오_시작시간_초
private int video_end_second; //비디오_종료시간_초
public String solution(String video_len, String pos, String op_start, String op_end, String[] commands) {
// 현재시간 초
int now = Integer.parseInt(pos.split(":")[0]) * 60 + Integer.parseInt(pos.split(":")[1]);
// 비디오 시작시간 초
video_start_second = 0;
// 비디오 종료시간 초
video_end_second = Integer.parseInt(video_len.split(":")[0]) * 60 + Integer.parseInt(video_len.split(":")[1]);
// 오프닝 시작시간 초
op_start_second = Integer.parseInt(op_start.split(":")[0]) * 60 + Integer.parseInt(op_start.split(":")[1]);
// 오프닝 종료시간 초
op_end_second = Integer.parseInt(op_end.split(":")[0]) * 60 + Integer.parseInt(op_end.split(":")[1]);
// 현재시간이 오프닝 시간에 포함이면
if(isOpening(now)){
now = op_end_second; // 오프닝 종료시간 저장
}
// 명령어 반복
for(String c : commands){
// next 이면
if("next".equals(c)){
int next = now+10;
// 오프닝 시간 확인
if(isOpening(next)){
now = op_end_second;
}
// 비디오 종료 시간 확인
else if(isVideoEnd(next)){
now = video_end_second;
}
// 둘 다 아니면
else{
now = next;
}
}
// prev 이면
else if("prev".equals(c)){
int prev = now-10;
// 오프닝 시간 확인
if(isOpening(prev)){
now = op_end_second;
}
// 비디오 시작 시간 확인
else if(isVideoStart(prev)){
now = video_start_second;
// 오프닝 시간 재확인
if(isOpening(now)){
now = op_end_second;
}
}
// 둘 다 아니면
else{
now = prev;
}
}
}
// 현재시간을 mm:ss 형태로 변환
String minute = String.format("%2s",String.valueOf(now/60)).replace(" ","0");
String second = String.format("%2s",String.valueOf(now%60)).replace(" ","0");
return minute+":"+second;
}
// 비디오 시작 시간 확인
boolean isVideoStart(int second){
if(second <= video_start_second) return true;
return false;
}
// 비디오 종료 시간 확인
boolean isVideoEnd(int second){
if(second >= video_end_second) return true;
return false;
}
// 오프닝 시간 확인
boolean isOpening(int second){
if(second >= op_start_second && second <= op_end_second) return true;
return false;
}
}
[실행결과]
'코딩 > 프로그래머스' 카테고리의 다른 글
[프로그래머스/JAVA] PCCP 기출문제 > 3번 > 충돌위험 찾기 (by 다알쥐AI) (0) | 2024.10.30 |
---|---|
[프로그래머스/JAVA] PCCP 기출문제 > 2번 > 퍼즐 게임 챌린지 (by 다알쥐AI) (1) | 2024.10.29 |
[프로그래머스/JAVA] 고득점Kit > 이분탐색 > 징검다리 (by 다알쥐AI) (0) | 2024.10.24 |
[프로그래머스/JAVA] 고득점Kit > 동적계획법(Dynamic Programming) > 도둑질 (by 다알쥐AI) (4) | 2024.10.23 |
[프로그래머스/JAVA] 고득점Kit > 동적계획법(Dynamic Programming) > 등굣길 (by 다알쥐AI) (2) | 2024.10.22 |