728x90
최빈값 알고리즘에 대해 알아보자!
Q. 최빈값 구하기
문제 설명
최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 array가 매개변수로 주어질 때, 최빈값을 return 하도록 solution 함수를 완성해보세요. 최빈값이 여러 개면 -1을 return 합니다.
제한 사항
- 0 < array의 길이 < 100
- 0 ≤ array의 원소 < 1000
입출력 예
array | result |
[1, 2, 3, 3, 3, 4] | 3 |
[1, 1, 2, 2] | -1 |
[1] | 1 |
입출력 예 설명
- 입출력 예 #1
[1, 2, 3, 3, 3, 4]에서 1은 1개 2는 1개 3은 3개 4는 1개로 최빈값은 3입니다. - 입출력 예 #2
[1, 1, 2, 2]에서 1은 2개 2는 2개로 최빈값이 1, 2입니다. 최빈값이 여러 개이므로 -1을 return 합니다. - 입출력 예 #3
[1]에는 1만 있으므로 최빈값은 1입니다.
solution.js
function solution(array) {
const freq = [];
let answer = 0;
let mode = [];
for (let num of array) {
if (freq[num] === undefined) freq[num] = 1;
else freq[num]++;
if (freq[num] > answer) {
answer = freq[num];
mode = [num];
}
else if (freq[num] === answer) mode.push(num);
}
if (mode.length >= 2) return -1;
return mode[0];
}
728x90
반응형
'TIL > 알고리즘' 카테고리의 다른 글
알고리즘 - 삼각 달팽이 (0) | 2023.08.23 |
---|---|
알고리즘 - 행렬의 곱셈 (0) | 2023.08.23 |
조금 어려운 알고리즘 - 옹알이(1) (0) | 2023.08.18 |
아주 어려운 알고리즘 - 단속 카메라 (0) | 2023.08.07 |
조금 어려운 알고리즘 - 예매 순위 (0) | 2023.08.02 |
댓글