😈 최빈값 구하기
📗 문제 설명
최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 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입니다.
💎나의 풀이
객체를 사용하여 풀이를 했다.
우전 new Map 을통해 새로운 객체를 생성하자.
const solution = array => {
let map = new Map();
}
문제의 요구사항대로 빈도를 추적할 수 있게 초기화를 해주자.
const solution = array => {
let map = new Map();
// map 객체 초기화
for(let i = 0; i <= Math.max(...array); i++){
map.set(i,0);
}
}
이후 원소 값이 일치하면 map객체의 key 값이 증가하게 해주자.
const solution = array => {
let map = new Map();
// map 객체 초기화
for(let i = 0; i <= Math.max(...array); i++){
map.set(i,0);
}
// array 원소값과 일치하면 map의 key 증가
for(let i = 0; i < array.length; i++){
map.set(array[i], map.get(array[i])+1)
}
}
map의 value를 모아서 배열을 따로 만들고
여기서 제일 큰 수를 max 변수로 사용하자.
const solution = array => {
let map = new Map();
// map 객체 초기화
for(let i = 0; i <= Math.max(...array); i++){
map.set(i,0);
}
// array 원소값과 일치하면 map의 key 증가
for(let i = 0; i < array.length; i++){
map.set(array[i], map.get(array[i])+1)
}
// map의 value만 모아서 배열 생성
let arr = [...map.values()]
// values의 최댓값 저장
let max = Math.max(...arr);
// 최댓값이 하나만 있다면 max 값 아니면 -1
return arr.indexOf(max) === arr.lastIndexOf(max) ? arr.indexOf(max) : -1
}
객체활용에 대해서는 아직 부족하다.
공부를 더하자.
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스 😈] JavaScript 홀수 vs 짝수 (0) | 2023.10.26 |
---|---|
[프로그래머스 😈] JavaScript 2차원으로 만들기 (0) | 2023.10.26 |
[프로그래머스 😈] JavaScript 안전지대 (0) | 2023.10.25 |
[프로그래머스 😈] JavaScript OX퀴즈 (0) | 2023.10.24 |
[프로그래머스 😈] JavaScript 배열의 길이에 따라 다른 연산하기 (0) | 2023.10.24 |