최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 array
가 매개변수로 주어질 때, 최빈값을 return 하도록 solution 함수를 완성해보세요. 최빈값이 여러 개면 -1을 return 합니다.
array
의 길이 < 100array
의 원소 < 1000array | result |
---|---|
[1, 2, 3, 3, 3, 4] | 3 |
[1, 1, 2, 2] | -1 |
[1] | -1 |
입출력 예 #1
입출력 예 #2
입출력 예 #3
public class Solution {
public int solution(int[] array) {
int answer = 0;
int maxArr = 0;
// array 최대값 구하기
for(int i = 0; i < array.Length; i++)
{
if(array[i] > maxArr)
{
maxArr = array[i];
}
}
int[] count = new int[maxArr + 1];
int max = 0;
int num = 0;
// array의 들어있는 값을 count 배열 번호에 넣고 개수가 있는 만큼 추가
for(int i = 0; i < array.Length; i++)
{
count[array[i]]++;
}
// count 배열중 가장 많이 나온 숫자 찾기
for(int i = 0; i < count.Length; i++)
{
if(count[i] > max)
{
max = count[i];
answer = i;
}
}
// count 배열중 가장 많이 나온 개수랑 같은 개수가 있는지 찾기
for(int i = 0; i < count.Length; i++)
{
if(count[i] == max)
{
num++;
}
}
// 개수가 같은 값이 1개 이상인 경우 찾기
if(num > 1)
{
answer = -1;
}
return answer;
}
}
출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges