https://school.programmers.co.kr/learn/courses/30/lessons/120812
최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 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, 2, 3, 3, 3, 4]에서 1은 1개 2는 1개 3은 3개 4는 1개로 최빈값은 3입니다.
[1, 1, 2, 2]에서 1은 2개 2는 2개로 최빈값이 1, 2입니다. 최빈값이 여러 개이므로 -1을 return 합니다.
[1]에는 1만 있으므로 최빈값은 1입니다.
class Solution {
public int solution(int[] array) {
int answer = 0;
int count=0;
int max=0;
int temp=0;
for(int i=0;i<array.length;i++){ //정렬
for(int j=i+1;j<array.length;j++){
if(array[j]<array[i]){
temp=array[j];
array[j]=array[i];
array[i]=temp;
}
}
}
for(int i=0;i<array.length;i++){ //최빈값 탐색
count=0;
for(int j=i;j<array.length;j++){
if(array[i]==array[j]){
count=count+1;
}
else break;
}
if(max<count){
max=count;
answer=array[i];
}
else if(max==count){
answer=-1;
}
i=i+count-1;
}
return answer;
}
}
처음에 입력값을 제일 작은 수 부터 정렬을 해주고,
count
값을 구해서 만약 카운트가 max
보다 크다면 답은 그 max값을 가지는 array[i]인 것이고, i=i+count-1
에서 생각을 못했었는데 i++
가 되기 때문에 -1
을 해줘야한다!