Algorithm/백준알고리즘

[백준알고리즘] 1차원 배열 5단계 -1546번 평균(JAVA)

개발자하소서 2022. 6. 24. 11:01
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