Task description
시간별 개구리의 위치 정보를 담고있는 배열 A(배열 인덱스가 초단위 시간, 값이 위치), 강의 끝 위치 X가 주어졌을 때 모든 위치를 거치게되는 가장 빠른 시간 찾기
모든 위치를 거치지 못한다면 -1을 반환
How I did solve
- 각 위치당 시간 정보를 가진 새로운 배열이 필요
- 각 위치를 배열의 index로 사용
- X 길이 만큼의 배열 생성
- 각 위치에 시간 기록
- 이미 기록된 위치에는 재작성하지 않아야 함
- 배열에 모든 요소가 값이 있다면 가장 높은 값을 반환
- 그렇지 않으면 -1 반환
Solved Code
function solution(X, A) {
let arr = new Array(X).fill(null)
for(let i = -1, entry; entry = A[++i]; ) {
if(arr[entry - 1] === null) arr[entry - 1] = i
}
if(arr.indexOf(null) > -1) return -1
return arr.sort( (a,b) => a - b).pop()
}
Retrospective
두 번 만에 풀었다...
처음엔 O(N)이 되기 전에 종료할 수 있으면 종료해보자는 생각으로
for(let i = -1, entry; entry = A[++i]; ) { if(arr[entry - 1] === null) arr[entry - 1] = i if(arr.indexOf(null) < 0) break }
이렇게 해봤었는데 Timeout이 걸리더라...
아무리 생각을 해봐도 결국 A를 전부 다 훑어야만 결과가 나올 수 있을 것 같아서 해당 라인을 제거하고나니 통과...O(N)이 나오는건 여전히 찝찝하다... 다른 방법이 없는지 좀 더 고민을...