문제설명
전체 스테이지의 개수 N, 게임을 이용하는 사용자가 현재 멈춰있는 스테이지의 번호가 담긴 배열 stages가 매개변수로 주어질 때, 실패율이 높은 스테이지부터 내림차순으로 스테이지의 번호가 담겨있는 배열을 return 하도록 solution 함수를 완성하라.
제한사항
- 스테이지의 개수 N은 1 이상 500 이하의 자연수이다.
- stages의 길이는 1 이상 200,000 이하이다.
- stages에는 1 이상 N + 1 이하의 자연수가 담겨있다.
- 각 자연수는 사용자가 현재 도전 중인 스테이지의 번호를 나타낸다.
- 단, N + 1 은 마지막 스테이지(N 번째 스테이지) 까지 클리어 한 사용자를 나타낸다.
- 만약 실패율이 같은 스테이지가 있다면 작은 번호의 스테이지가 먼저 오도록 하면 된다.
- 스테이지에 도달한 유저가 없는 경우 해당 스테이지의 실패율은 0 으로 정의한다.
풀이
import java.util.*;
class Solution {
public int[] solution(int N, int[] stages) {
int[] check = new int[N]; // 1단계의 값을 저장할 배열
double[] rate = new double[N]; // 2단계의 실패율을 저장할 배열
int[] answer = new int[N];
/*
* 1단계 N까지의 자연수에 대응되는 값의 갯수
*/
for (int i = 0; i < N; i++) {
for (int j = 0; j < stages.length; j++) {
if (stages[j] == i + 1) {
check[i]++;
}
}
}
/*
* 2단계 실패율을 구하는 곳
*/
int denominator = stages.length;
for (int i = 0; i < check.length; i++) {
int numerator = check[i];
if (denominator == 0) {
rate[i] = 0;
} else {
rate[i] = (double) numerator / denominator;
}
denominator -= check[i];
}
/*
* 3단계 answer을 구한다 (selection sort 방법 이용)
*/
double max = 0;
int target = 1;
for (int i = 0; i < rate.length; i++) {
max = rate[0];
target = 1;
for (int j = 0; j < rate.length; j++) {
if (rate[j] > max) {
max = rate[j];
target = j + 1;
}
}
rate[target - 1] = -1;
answer[i] = target;
}
return answer;
}
}
728x90
'코딩 테스트 > 프로그래머스' 카테고리의 다른 글
[ 프로그래머스 - java ] 최소직사각형 (위클리 챌린지) (0) | 2022.04.13 |
---|---|
[ 프로그래머스 - java ] 비밀지도 ( 2018 KAKAO BLIND RECRUITMENT ) (0) | 2022.04.07 |
[ 프로그래머스 - java ] 체육복 (탐욕법) (0) | 2022.03.25 |
[ 프로그래머스 - java ] 모의고사 (완전탐색) (0) | 2022.03.25 |
[ 프로그래머스 - java ] 폰켓몬 (찾아라 프로그래밍 마에스터) (0) | 2022.03.24 |
댓글