알고리즘 풀이 - 실패율

picture 22

실패율

문제 링크

문제 요약

  • 실패율 = 스테이지에 도달했으나 아직 클리어하지 못한 플레이어의 수 / 스테이지에 도달한 플레이어 수

제한사항

  • 스테이지의 개수 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
}

Written by@박대성

독서와 지식관리에 관심이 많은 개발자

GitHub