프로그래머스

[C언어/프로그래머스 레벨0]-최빈값 구하기

이상한 코딩 2022. 11. 13. 18:13
728x90

 

 

군대에서 코딩하기

문제 설명

최빈값은 주어진 값 중에서 가장 자주 나오는 값을 의미합니다. 정수 배열 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입니다.

[소스코드]

#include <stdio.h>


// array_len은 배열 array의 길이입니다.
int solution(int array[], size_t array_len) {
    int answer = 0;
    int count=-1,t=-1;//비교를 위해 값이 같아야함
    
    for(int i=0;i<array_len;i++){
     for(int j=i;j<array_len;j++){
         
        
        if(array[i]==array[j]){
            count++;
        }//같은값이 있으면 count++
     }
            if(t==count){//만약 최빈값이 2개이상이면 -1
                answer=-1;
            }
            
            
            if(t<count){
               t=count;
               answer=array[i]; }
                       
            count=-1;
            }
        
    
    
    return answer;
}

원리는 간단하다.이중 반복문으로 같은 값을 찾고 count++을 해 줬을 때 가장 높게나온 값이 최빈값이 된다.

count=-1인 이유는 i와 j가 같기때문에 같은 값을 한번 더

세주기 때문. 물론 j를 i+1로 두고 count=0; t=-1로 둬도된다.