문제 설명
최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 `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입니다.
나의 풀이
class Solution {
public int solution(int[] array) {
if(array.length<0 || array.length>100){
throw new IllegalArgumentException("배열 길이는 0 초과 100 미만입니다.");
}
int[] count = new int[1000];
for(int i=0; i<array.length; i++){
int number =array[i];
count[number] += 1;
}
int result = -1;
int maxFrequency = 0;
for(int j=0; j<count.length; j++){
if(count[j] > maxFrequency){
result = j;
maxFrequency = count[j];
}else if(count[j] == maxFrequency && maxFrequency > 0){
result = -1;
}
}
return result;
}
public static void main(String[] args) {
Solution st = new Solution();
int[] test1 = {1, 2, 3, 3, 3, 4};
System.out.println(st.solution(test1));
int[] test2 = {1, 1, 2, 2};
System.out.println(st.solution(test2));
int[] test3 = {1};
System.out.println(st.solution(test3));
}
}
다른 풀이
'👨💻 Coding Test > Java' 카테고리의 다른 글
[Programmers/Java/Lv.0] 15.피자 나눠 먹기 (1) (0) | 2024.09.20 |
---|---|
[Programmers/Java/Lv.0] 14.짝수는 싫어요 (0) | 2024.09.20 |
[Programmers/Java/Lv.0] 12.중앙값 구하기 (0) | 2024.09.18 |
[Programmers/Java/Lv.0] 11.나머지 구하기 (0) | 2024.09.15 |
[Programmers/Java/Lv.0] 10.배열 두 배 만들기 (0) | 2024.09.14 |