일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- MYSQL
- Spring
- CS
- SW Expert Academy
- 자바
- SWEA
- 회원가입
- Spotify Api
- programmers
- java
- Baekjoon
- Gem
- 프로그래머스
- spotify
- 파이썬
- linux
- modern c++
- 백준
- c
- SECS/GEM
- Computer Science
- C++
- 스포티파이
- regression
- 회귀
- Spring JPA
- python
- SECS-II
- spring boot
- SECS
- Today
- Total
비버놀로지
[Programmers 프로그래머스] 340213 [PCCP 기출문제] 1번 / 동영상 재생기 (C 언어) 본문
[Programmers 프로그래머스] 340213 [PCCP 기출문제] 1번 / 동영상 재생기 (C 언어)
KUNDUZ 2024. 12. 23. 22:57https://school.programmers.co.kr/learn/courses/30/lessons/340213
문제 설명
당신은 동영상 재생기를 만들고 있습니다. 당신의 동영상 재생기는 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" |
입출력 예 설명
입출력 예 #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 하면 됩니다.
먼저 malloc의 경우 char*를 동적할당 해주는 의미를 가지고 있다.
이문제를 해결하기 위해 모든 시간을 초로 변경을 해서 문제를 해결했다.
그리고 최종적인 초가 구해졌을때 다시 분과 초로 이루어진 char*로 변경을 해야하는데,
char* temp=(char*)malloc(10);
int값을 변경하기 위해 sprintf(temp, "%d", 100); 를 사용하게 되면 temp에 "100"이 들어가게 된다.
이렇게 만들어진 char* 값을 answer에 붙여줘야하는데, 이때 strcat(answer,temp); 를 이용을 해서 answer에 문자를 뒤에 붙여 준다.
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <string.h>
// commands_len은 배열 commands의 길이입니다.
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
char* solution(const char* video_len, const char* pos, const char* op_start, const char* op_end, const char* commands[], size_t commands_len) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
char* answer = (char*)malloc(10);
memset(answer, '\0', 10);
int video_len_second=0;
int now_second=0;
int op_start_second=0;
int op_end_second=0;
char* temp = (char*)malloc(10);
//모든 시간을 초로 변환
video_len_second+=((int)video_len[0]-48)*600;
video_len_second+=((int)video_len[1]-48)*60;
video_len_second+=((int)video_len[3]-48)*10;
video_len_second+=((int)video_len[4]-48);
now_second+=((int)pos[0]-48)*600;
now_second+=((int)pos[1]-48)*60;
now_second+=((int)pos[3]-48)*10;
now_second+=((int)pos[4]-48);
op_start_second+=((int)op_start[0]-48)*600;
op_start_second+=((int)op_start[1]-48)*60;
op_start_second+=((int)op_start[3]-48)*10;
op_start_second+=((int)op_start[4]-48);
op_end_second+=((int)op_end[0]-48)*600;
op_end_second+=((int)op_end[1]-48)*60;
op_end_second+=((int)op_end[3]-48)*10;
op_end_second+=((int)op_end[4]-48);
//commands에 맞게 시간 이동
for(int i=0; i<commands_len; i++){
if(op_start_second<=now_second && now_second<=op_end_second){
now_second=op_end_second;
}
if(strcmp(commands[i],"next")==0){
now_second+=10;
if(now_second>video_len_second){
now_second=video_len_second;
}
}else if(strcmp(commands[i],"prev")==0){
now_second-=10;
if(now_second<0){
now_second=0;
}
}
}
if(op_start_second<=now_second && now_second<=op_end_second){
now_second=op_end_second;
}
if(now_second/60<10){
strcat(answer,"0");
}
//sprintf의 경우 숫자를 char*로 변경을 해준다.
sprintf(temp, "%d", now_second/60);
//answer에 temp를 이어 붙여준다.
strcat(answer,temp);
strcat(answer,":");
sprintf(temp, "%d", now_second%60);
if(now_second%60<10){
strcat(answer,"0");
}
strcat(answer,temp);
return answer;
}
'ALGORITM > C C++' 카테고리의 다른 글
[Programmers 프로그래머스] 42860 조이스틱 (C 언어) (0) | 2024.12.22 |
---|---|
[JUNGOL 정올] 2514 문자열 찾기 (C++) (0) | 2023.01.12 |
[JUNGOL 정올] 3116 긴 자리 진법 변환 (C++) (0) | 2023.01.12 |
[JUNGOL 정올] 1534 10진수를 2,8,16진수로 (C++) (0) | 2023.01.12 |
[JUNGOL 정올] 2809 약수 (C++) (0) | 2023.01.12 |