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

2024. 11. 15. 18:17·🐸 Problem Solving/Programmers

 

문제

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

 

제한 사항

 

 

 

입출력 예시

입출력 예시

 

입출력 예시 설명

 

 

 


 

풀이 

  • `mm:ss` 형식의 입력 값에 대해 원활한 연산을 위해 전부 초 단위로 변환하는 과정을 거쳤다.
  • 맨 처음 프로그램 실행 후, 오프닝 구간인지 검사(`IsOp()`)를 진행하고, 명령어 처리에 따른 연산을 진행한 후에도 `IsOp()`로 꼭 검사를 해야한다.
  • 명령어들을 전부 처리한 후, 초 단위로 바꾸어놨던 것을 다시 문제에서 원하는 형식인 `mm:ss`로 변환하여 최종 문자열(result)을 반환한다.
#include <algorithm>
#include <vector>
#include <string>
using namespace std;

int _video_len, _pos, _op_start, _op_end;

bool IsOp(int pos) {
    if (_op_start <= pos && pos < _op_end) 
        return true;
    else 
        return false;
}

string solution(string video_len, string pos, string op_start, string op_end, vector<string> commands) {
    /* 전체 시간을 초 단위로 변환 */
    _video_len = 60 * stoi(video_len.substr(0, 2)) + stoi(video_len.substr(3, 5));
    _pos = 60 * stoi(pos.substr(0, 2)) + stoi(pos.substr(3, 5));
    _op_start = 60 * stoi(op_start.substr(0, 2)) + stoi(op_start.substr(3, 5));
    _op_end = 60 * stoi(op_end.substr(0, 2)) + stoi(op_end.substr(3, 5));

    /* 현재 재생 위치가 오프닝 구간일 경우 */
    if (IsOp(_pos)) {
        _pos = _op_end;
    }

    /* 명령어 처리 */
    for(string& comm : commands) {
        if (comm == "next") {
            _pos = min(_video_len, _pos + 10);
            if (IsOp(_pos)) {
                _pos = _op_end;
            }
        }
        else if (comm == "prev") {
            _pos = max(0, _pos - 10);
            if (IsOp(_pos)) {
                _pos = _op_end;
            }
        }
    }

    /* 초 단위인 시간을 mm:ss 형식으로 변환 */
    int tmp;
    tmp = _pos / 60;
    string mm = (tmp < 10 ? "0" : "") + to_string(tmp);
    tmp = _pos % 60;
    string ss = (tmp < 10 ? "0" : "") + to_string(tmp);
    string result = mm + ":" + ss;
    
    return result;
}

 

 

 


 

저작자표시 비영리 변경금지 (새창열림)

'🐸 Problem Solving > Programmers' 카테고리의 다른 글

[Programmers/C++] [PCCE 기출문제] 1번 / 문자 출력  (0) 2024.11.17
[Programmers/C++] 뒤에 있는 큰 수 찾기  (0) 2024.09.01
[Programmers/C++] [PCCP 기출문제] 2번 / 석유 시추  (0) 2024.08.22
'🐸 Problem Solving/Programmers' 카테고리의 다른 글
  • [Programmers/C++] [PCCE 기출문제] 2번 / 각도 합치기
  • [Programmers/C++] [PCCE 기출문제] 1번 / 문자 출력
  • [Programmers/C++] 뒤에 있는 큰 수 찾기
  • [Programmers/C++] [PCCP 기출문제] 2번 / 석유 시추
Mojing_
Mojing_
매일 매일 경험치를 쌓는 모징이의 개발 블로그입니다 :) This is Mojing’s Dev Blog where she gain experience points every day. :)
  • Mojing_
    모징이의 개발 경험치
    Mojing_
  • 전체
    오늘
    어제
    • 분류 전체보기 (143) N
      • 👻 Unity (5) N
        • 🔧 기능 구현 (0)
        • 💡 유니티 팁 (0)
        • 📘 Unity 노트 (2) N
      • 💻 Programming (14)
        • C (3)
        • C++ (9)
        • C# (0)
        • Swift (2)
      • 💾 Computer Science (16)
        • Algorithm (9)
        • Software Engineering (7)
      • 🐸 Problem Solving (108)
        • Programmers (41)
        • BOJ (67)
      • 🔋 ETC (0)
      • 💡 Quest Log (0)
  • 인기 글

  • 공지사항

  • 태그

    DFS/BFS
    오블완
    Design Pattern
    Problem Solving
    sort
    BOJ
    CS
    dynamic programming
    티스토리챌린지
    algorithm
    프로그래머스
    탐색
    programmers
    C++
    backtracking
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Mojing_
[Programmers/C++] [PCCP 기출문제] 1번 / 동영상 재생기
상단으로

티스토리툴바