프로그래머스/Lv.0

[프로그래머스/JAVA] 최빈값 구하기

챌인! 2023. 5. 26. 23:20
최빈값 구하기

 

1. 문제설명

최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 array가 매개변수로 주어질 때, 최빈값을 return 하도록 solution 함수를 완성해보세요. 최빈값이 여러 개면 -1을 return 합니다.

 

2. 제한사항

  • 0 < array의 길이 < 100
  • 0 <= array의 원소 < 1000

 

입출력 예

array result
[1,2,3,3,3,4] 3
[1,1,2,2] -1
[1] 1

 

3. 입출력 예 설명

입출력 예 #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입니다.

 

4. 소스코드

import java.util.*;

class Solution {
    public int solution(int[] array) {
        
        int answer = 0;        
        
        Arrays.sort( array );   // 오름차순 정렬
        
        int idx = 0;            // 빈도수 체크 변수
        int tmp = 0;
        
        for( int i=0; i<array.length; i++ )
        {
            idx++;
           
            if( ((i+1) == array.length) || (array[i] != array[i+1]) )
            {
                if( tmp == idx )
                {
                    answer = -1;
                }
                else if( tmp < idx )
                {
                    answer = array[i];
                    tmp = idx;
                }    

                idx = 0;
            }
        }
        
        return answer;
    }
}

 

 

5. 실행결과

 

6. 문제출처

https://school.programmers.co.kr/learn/courses/30/lessons/120812

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr