문제
세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 M이라고 한다. 그리고 나서 모든 점수를 점수/M*100으로 고쳤다.
예를 들어, 세준이의 최고점이 70이고, 수학점수가 50이었으면 수학점수는 50/70*100이 되어 71.43점이 된다.
세준이의 성적을 위의 방법대로 새로 계산했을 때, 새로운 평균을 구하는 프로그램을 작성하시오.
입력
첫째 줄에 시험 본 과목의 개수 N이 주어진다. 이 값은 1000보다 작거나 같다. 둘째 줄에 세준이의 현재 성적이 주어진다. 이 값은 100보다 작거나 같은 음이 아닌 정수이고, 적어도 하나의 값은 0보다 크다.
출력
첫째 줄에 새로운 평균을 출력한다. 실제 정답과 출력값의 절대오차 또는 상대오차가 10-2 이하이면 정답이다.
예제 입력 1
3
40 80 60
예제 출력 1
75.0
예제 입력 2
3
10 20 30
예제 출력 2
66.666667
10-2 이하의 오차를 허용한다는 말은 정확히 소수 2번째 자리까지 출력하라는 뜻이 아니다.
예제 입력 3
4
1 100 100 100
예제 출력 3
75.25
예제 입력 4
5
1 2 4 8 16
예제 출력 4
38.75
예제 입력 5
2
3 10
예제 출력 5
65.0
예제 입력 6
4
10 20 0 100
예제 출력 6
32.5
예제 입력 7
1
50
예제 출력 7
100.0
예제 입력 8
9
10 20 30 40 50 60 70 80 90
예제 출력 8
55.55555555555556
해결 아이디어
입력 n개를 받을 때 입력마다 max를 검사하여 입력이 모두 끝날때 max를 가진 상태에서 입력값들을 조건에 맞게 계산하도록 하였다. vector를 사용하여 유동적으로 크기가 변하는 입력 개수에 따라 효율적으로 접근하는것을 의도하였고, max를 따로 계산하여 vector의 sort() 함수를 사용하지 않고 문제를 해결하도록 접근하였다.
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
|
#include <iostream>
#include <vector>
using namespace std;
int main()
{
int n;
double val, max = -1.0;
vector<double> vals;
cin >> n;
for (int i = 0; i < n; ++i)
{
cin >> val;
vals.push_back(val);
max = val > max ? val : max;
}
double sum = 0;
for (vector<double>::iterator iter = vals.begin(); iter != vals.end(); ++iter)
{
sum += *iter / max * 100.0;
}
cout << sum / n;
}
|
cs |
'algorithms (C++)' 카테고리의 다른 글
[C++] 백준 2581번 / 소수 (0) | 2022.07.24 |
---|---|
[C++] 백준 1978번 / 소수 찾기 (0) | 2022.07.24 |
[C++] 백준 2522번 / 별 찍기 - 12 (0) | 2022.07.23 |
[C++] 백준 10952번 / A + B - 5 (0) | 2022.07.23 |
[C++] 백준 10950번 / A+B - 3 (0) | 2022.07.23 |