e_yejun
Jun_ : Pwn
e_yejun
전체 방문자
오늘
어제
  • 분류 전체보기 (240)
    • Profile (1)
    • Pwnable (54)
    • Reversing (14)
    • Network (8)
    • Forensic (10)
    • Embedded (4)
    • Android (2)
    • Web (18)
    • 알고리즘 (42)
    • 프로그래밍 (24)
    • 프로젝트 (6)
    • 1-day (7)
    • CTF (15)
    • 기타 (33)
    • 일기장 (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • X86
  • BOF
  • 1-day
  • Heap
  • wargame
  • rev-basic
  • dvwa
  • how2heap
  • dreamhack.io
  • x64

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
e_yejun

Jun_ : Pwn

알고리즘

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

2024. 12. 16. 14:26

문제 설명

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

 

 

문제 풀이

먼저 "시간:분"으로 나뉜 형식을 분 형태로 만든 후 각 기능에 대해 수행하고 마지막에 다시 "시간:분" 형태로 변환하면 쉽게 풀이할 수 있다. 마지막에 오프닝 범위에 들어가는지 확인해주는 부분도 필요하다.

 

 

풀이 코드

def time_to_minute(times):
    return int(times[:2]) * 60 + int(times[3:])


def minute_to_time(times):
    return f"{times // 60:02}:{times % 60:02}"


def solution(video_len, pos, op_start, op_end, commands):
    pos = time_to_minute(pos)
    video_len = time_to_minute(video_len)
    op_start = time_to_minute(op_start)
    op_end = time_to_minute(op_end)
    
    for cmd in commands:
        if pos >= op_start and pos <= op_end:
                pos = op_end
                
        if cmd == "prev":
            pos = pos - 10 
            if pos < 10 :
                pos = 0
                continue     
        elif cmd == "next":
            pos = pos + 10
            if pos > video_len-10:
                pos = video_len
        
    if pos >= op_start and pos <= op_end:
            pos = op_end
    
    return minute_to_time(pos)

 

 

    '알고리즘' 카테고리의 다른 글
    • [Programmers/Python] [PCCE 기출문제] 10번 / 공원
    • [Programmers/Python] [PCCE 기출문제] 9번 / 지폐 접기
    • [BOJ/Python] 백준 17614 - 369
    • [Codeup] 1157-1159 특별한 공 던지기 - Python 풀이
    e_yejun
    e_yejun
    정리노트 •_•

    티스토리툴바