January 09, 2021
제한사항
- 스테이지의 개수 N은 1 이상 500 이하의 자연수이다.
- stages의 길이는 1 이상 200,000 이하이다.
- stages에는 1 이상 N + 1 이하의 자연수가 담겨있다.
- 각 자연수는 사용자가 현재 도전 중인 스테이지의 번호를 나타낸다.
- 단, N + 1 은 마지막 스테이지(N 번째 스테이지) 까지 클리어 한 사용자를 나타낸다.
- 만약 실패율이 같은 스테이지가 있다면 작은 번호의 스테이지가 먼저 오도록 하면 된다.
- 스테이지에 도달한 유저가 없는 경우 해당 스테이지의 실패율은 0 으로 정의한다.
Input
- 전체 스테이지의 개수 N,
- 게임을 이용하는 사용자가 현재 멈춰있는 스테이지의 번호가 담긴 배열 stages
output
- 실패율이 높은 스테이지부터 내림차순으로 스테이지의 번호가 담겨있는 배열
function solution(N, stages) {
const map = new Map()
for (let i = 1; i <= N + 1; i++) {
map.set(i, 0)
}
for (let i = 0; i < stages.length; i++) {
const stage = stages[i]
map.set(stage, map.get(stage) + 1)
}
const result = [...map.entries()]
.map((s, i, arr) => {
return [s[0], s[1] / arr.slice(i).reduce((a, b) => a + b[1], 0)]
})
.filter(s => s[0] !== N + 1)
.sort((a, b) => {
if (b[1] === a[1]) {
return a[1] - b[1]
}
return b[1] - a[1]
})
.map(s => s[0])
return result
}