2024-11-15 TIL
오늘 배운 것Permalink
- 프로젝트 제출
기존 작업하던 결과물을 완결내고 제출했다.
오랜만에 게임을 만들어보려고 하는 작업은 역시 힘든 작업이었다.
그래도 오래간만에 뭔가 제대로 된 걸 해냈다는 성취감은 있다.
- 코딩 테스트
문제를 풀면서 느낀 점은 아직도 내가 사고가 딱딱하다는 것이다.
사고를 조금만 다르게 하면 금방 풀리는 문제를 하나 풀겠다고 거의 4시간을 붙잡았던 것 같다.
문제 설명Permalink
당신은 동영상 재생기를 만들고 있습니다. 당신의 동영상 재생기는 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 함수를 완성해 주세요. </span>
function tominuite(data)
{
const [h, m] = data.split(":");
return Number(h) * 60 + Number(m);
}
function solution(video_len, pos, op_start, op_end, commands) {
var answer = '';
let video_len_arr = tominuite(video_len);
let pos_arr = tominuite(pos);
let op_start_arr = tominuite(op_start);
let op_end_arr = tominuite(op_end);
if(pos_arr >= op_start_arr && pos_arr <= op_end_arr)
pos_arr = op_end_arr;
commands.forEach(data => {
let check = data === "next" ? 10 : -10;
pos_arr += check;
if(pos_arr < 0)
pos_arr = 0;
if(pos_arr > video_len_arr)
{
pos_arr = video_len_arr;
}
if(pos_arr >= op_start_arr && pos_arr <= op_end_arr)
pos_arr = op_end_arr;
});
const [h, w] = [Math.floor(pos_arr/60), pos_arr%60 >= 10? pos_arr%60 : `0${pos_arr%60}`];
answer = [h,w].join(":");
return answer;
}
이 문제를 풀기 위해 원래는 시간과 분을 따로 나눠서 split(“:”)을 이용해 분리하여 작업하였다.
그렇게 하자 작업해야 할 게 배 이상 늘어났고, 코드가 길어지면서 가독성이 떨어져 이해도 힘들어지게 되었다.
해당 방법을 풀기 위한 문제를 고민해보던 가운데 다른 문제를 훑어 보다 변수를 하나의 값을 치환하자는 방법이 제시되어 시도해 보았고, 그 결과 성공했다.
간단한 방법이 있었는데 그걸 알기 위해 몇 시간을 허비한 게 좀 많이 한심하게 느껴졌다.
다음에 할 것Permalink
월요일에 어떤 식으로 진행이 될지를 좀 알아봐야 할 것 같다.