본문 바로가기
[C++] 알고리즘 교육/1~4. 기본기

[알고리즘 3.1.15] 간단한 완전 탐색 - 대푯값

by 안산학생 2019. 4. 26.

문제


어떤 수들이 있을 때, 그 수들을 대표하는 값으로 가장 흔하게 쓰이는 것은 평균이다. 평균은 주어진 모든 수의 합을 수의 개수로 나눈 것이다. 예를 들어 10, 40, 30, 60, 30, 20, 60, 30, 40, 50의 평균은

이 된다.

평균 이외의 또 다른 대표값으로 최빈값이라는 것이 있다. 최빈값은 주어진 수들 가운데 가장 많이 나타나는 수이다. 예를 들어 10, 40, 30, 60, 30, 20, 60, 30, 40, 50 이 주어질 경우, 30 이 세 번, 40 과 60 이 각각 두 번, 10, 20, 50 이 각각 한 번씩 나오므로, 최빈값은 30 이 된다. 열 개의 자연수가 주어질 때 이들의 평균과 최빈값을 구하는 프로그램을 작성하시오.

 

입력


첫째 줄부터 열 번째 줄까지 한 줄에 하나씩 자연수가 주어진다. 주어지는 자연수는 1,000 이하의 10 의 배수이다.

 

출력


첫째 줄에는 평균을 출력하고, 둘째 줄에는 최빈값을 출력한다. 최빈값이 둘 이상일 경우 그 중 최소값을 출력한다. 평균과 최빈값은 모두 자연수이다.

 

예제 입력

10

40

30

60

30

20

60

30

40

50

예제 출력

37 30

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#include <stdio.h>
 
int main() {
 
  int arr[10][2];
  int i, j;
  int sum = 0;
  
  for(i=0;i<10;i++){
    scanf("%d"&arr[i][0]);
    sum += arr[i][0];
  }
  for(i=0;i<10;i++){
    arr[i][1= 0;
  }
  
  for(i=0;i<10;i++){
    for(j=0;j<10;j++){
      if(arr[i][0== arr[j][0]){
        arr[i][1]++;
      }
    }
  }
  
  //최빈값 찾을 것.
  int max = 0;
  int maxNum = 1000;
  for(i=0; i<10; i++){
    if(arr[i][1]>max){
      max = arr[i][1];
    }
  }
  
  for(i=0; i<10; i++){
    if(arr[i][1]==max){
      if(arr[i][0]<maxNum){
        maxNum = arr[i][0];
      }
    }
  }
  
 printf("%d\n",sum/10); 
 printf("%d",maxNum); 
  // for(i=0; i<10; i++){
  //   for(j=0; j<2; j++){
  //     printf("%d ",arr[i][j]);
  //   }
  //   printf("\n");
  // }
  
}
 

댓글