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

[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“ 형식으로 mmss초를 나타냅니다.
    • 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 하면 됩니다.

풀이과정

사실 이 문제에서 제일 헷갈리는 것은 바로 오프닝 스킵 기능이었다.

특히 입출력 예 3번에서 보여주는 4분 5초이기 때문에 4분 7초로 commands에 관련없이 ‘자동이동’한다는 것이었고 입출력 예 3번을 제대로 읽지 못한 나는 한동안 난리쇼를 펼쳤다는 것.


다른 분들은 mm, ss로 나누어서 비교를 많이 하셨던데
나는 그럴 필요 없이 그냥 시간을 전부 seconds로 바꾸어서 단위 일체화를 시켜두었다.

1
2
3
4
def time_to_sec(time):
mm, ss = map(int, time.split(":"))
secs = mm*60 + ss
return secs

answer를 내기 위해서 초단위가 되어버린 변수를 mm:ss 형태로 고치기 위해 필요한 함수

1
2
3
4
5
def sec_to_time(sec):
ss = sec%60
mm = sec//60
time = "{}:{}".format(str(mm).zfill(2),str(ss).zfill(2))
return time

오프닝을 스킵해야할지 말아야 할지에 대한 조건문

1
2
3
4
5
def check_skip(spos, sos, soe):
if spos >= sos and spos <= soe:
return True
else:
return False

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
def solution(video_len, pos, op_start, op_end, commands):
# 일단 모든 mm:ss화 된 변수들을 초단위로 바꾸어 비교하기 쉽게 만들어준다.
spos= time_to_sec(pos)
stotal = time_to_sec(video_len)
sos = time_to_sec(op_start)
soe = time_to_sec(op_end)

# answer가 될 position은 일단 시작 시간인 현재 pos과 일치하게 initialize
new_spos = spos
# 시작부터 오프닝을 스킵해야 할지 말지 결정해준다.
if check_skip(spos, sos, soe) : new_spos = soe

# 스킵을 했건 안했건 그 다음으로 커맨드를 받아준다.
for c in commands:
# next면 10초를 추가해주고
if c == 'next':
new_spos += 10
# prev면 10초를 감소해준다.
else:
new_spos -= 10
# 다만 영상길이가 -가 될 수는 없으므로 -가 되면 0으로 초기화 해준다.
if new_spos < 0:
new_spos = 0
# 커맨드를 받고 영상길이가 재조정 되었으니 이제 또 다시 오프닝 스킵인지 체크
if check_skip(new_spos, sos, soe) : new_spos = soe
# 마지막으로 영상 재조정 된 길이가 영상 총 길이보다 길면 안되므로 조절해준다.
if new_spos > stotal:
new_spos = stotal
answer = sec_to_time(new_spos)
print(answer)
return answer
Share 0 Comments