728x90
반응형
SMALL
📌문제
세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 M이라고 한다. 그리고 나서 모든 점수를 점수/M*100으로 고쳤다.
예를 들어, 세준이의 최고점이 70이고, 수학점수가 50이었으면 수학점수는 50/70*100이 되어 71.43점이 된다.
세준이의 성적을 위의 방법대로 새로 계산했을 때, 새로운 평균을 구하는 프로그램을 작성하시오.
📌입력
첫째 줄에 시험 본 과목의 개수 N이 주어진다. 이 값은 1000보다 작거나 같다. 둘째 줄에 세준이의 현재 성적이 주어진다. 이 값은 100보다 작거나 같은 음이 아닌 정수이고, 적어도 하나의 값은 0보다 크다.
📌출력
첫째 줄에 새로운 평균을 출력한다. 실제 정답과 출력값의 절대오차 또는 상대오차가 10-2 이하이면 정답이다.
📌코드
import java.util.*;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
// 과목의 개수를 입력받는다.
float[] subject = new float[n];
// 입력받은 개수만큼 과목의 점수를 배열로 설정한다.
float max = 0;
// 최대값 변수 선언
float avg = 0;
// 평균값 변수 선언
for(int i=0; i <subject.length; i++){
subject[i] = sc.nextInt();
// 입력받은 수를 과목 배열에 반복문을 통해 삽입한다.
if(subject[i] > max){
//만약 입력받은 과목의 점수가 최댓값보다 크다면
max = subject[i];
// 그 값을 최댓값에 넣는다.
}
}
for(int j=0; j<subject.length; j++){
avg += (subject[j]/max *100)/n;
// 반복문을 통해
// 입력받은 수들의 평균값을 구한다.
// 입력받은 수 / 최댓값 + 100
// 전부를 다시 입력받은 과목의 갯수로 나눠서
// 평균값을 구한다
}
System.out.println(avg);
}
}
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws Exception{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
// 과목의 갯수를 입력받기
StringTokenizer st = new StringTokenizer(br.readLine());
// 과목의 점수들을 공백 기준으로 나눠서 받아야 하기에 StringTokenizer 클래스 생성
int max = 0;
// 최댓값 변수 선언
double sum =0;
// 과목의 합계 변수 선언
for(int i =0; i<n; i++) {
int subject = Integer.parseInt(st.nextToken());
// 반복문으로 과목의 갯수만큼 과목의 점수를 입력받기
if(subject > max) {
max = subject;
// 입력받는 과목의 점수에서 최댓값이 나오면 max에 대입하기
}
sum += subject;
}
System.out.println((sum/max) * 100 /n);
}
}
728x90
반응형
LIST
'Algorithm > 백준알고리즘' 카테고리의 다른 글
[백준알고리즘] 1차원 배열 7단계 -4344번 평균은 넘겠지(JAVA) (0) | 2022.06.28 |
---|---|
[백준알고리즘] 1차원 배열 6단계 -8958번 OX퀴즈(JAVA) (0) | 2022.06.27 |
[백준알고리즘] 1차원 배열 4단계 -3052번 나머지(JAVA) (0) | 2022.06.23 |
[백준알고리즘] 1차원 배열 3단계 -2577번 숫자의 개수(JAVA) (0) | 2022.06.23 |
[백준알고리즘] 1차원 배열 2단계 -2562번 최댓값(JAVA) (0) | 2022.06.22 |