일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- Effective Java
- db
- BFS
- select
- 우선순위큐
- 코테
- mariaDB
- Database
- 그리디알고리즘
- IntelliJ
- 알고리즘
- 백준
- 피보나치
- 다이나믹프로그래밍
- mybatis
- DFS
- Spring
- 프로그래머스
- 깊이우선탐색
- java
- 이펙티브자바
- 데이터베이스
- join
- 탐욕법
- DP
- 정렬
- springboot
- Greedy
- 너비우선탐색
- SQL
Archives
- Today
- Total
땀두 블로그
[백준] 1546번 - 평균 본문
문제
세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 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
|
import java.util.Scanner;
public class p1546 {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
int a;
double max = 0;
double sum = 0;
a = sc.nextInt();
double[] ary = new double[a];
for (int i = 0; i < a; i++) {
ary[i] = sc.nextInt();
}
for (int i = 0; i < a; i++) {
if (ary[i] >= max) {
max = ary[i];
}
}
for (int i = 0; i < a; i++) {
sum += ary[i] / max * 100;
}
System.out.println(sum / a);
}
}
이 문제는 문제를 제대로 안읽으면 한번에 정답을 낼 수 없는 문제이다. 단순 평균이 아니라 max값을 통해서 값을 재구성하고 나누기 연산을 하면 된다.
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 2439번 - 별찍기-2 (0) | 2022.03.18 |
---|---|
[백준] 2438번 - 별찍기-1 (0) | 2022.03.18 |
[백준] 1157번 - 단어 공부 (0) | 2022.03.18 |
[백준] 1152번 - 단어의 개수 (0) | 2022.03.18 |
[백준] 1008번 - A/B (0) | 2022.03.18 |
Comments