본문 바로가기

Study/BEAKJOON Algorithm

5단계 1차원 배열

 

1. 평균 (문제 번호 : 1546)

 

문제 :

세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 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 scan = new Scanner(System.in);
		int n = scan.nextInt();
		double high = 0, sum = 0;
		double avg;
		
		double[] scores = new double[n];
		
		for (int i = 0; i < scores.length; i++) {
			scores[i] = scan.nextInt();
			if(high < scores[i]) {
				high = scores[i];
			}
		}
	
		for (int i = 0; i < scores.length; i++) {
			scores[i] = scores[i] / high * 100;
			
			sum += scores[i];
		}
		avg = (double) sum / n;
		System.out.println(avg);
	}
}

 

 

2. 평균은 넘겠지 (문제 번호 : 4344)

 

문제 : 

대학생 새내기들의 90%는 자신이 반에서 평균은 넘는다고 생각한다. 당신은 그들에게 슬픈 진실을 알려줘야 한다.

 

입력 :

첫째 줄에는 테스트 케이스의 개수 C가 주어진다.

둘째 줄부터 각 테스트 케이스마다 학생의 수 N(1 ≤ N ≤ 1000, N은 정수)이 첫 수로 주어지고, 이어서 N명의 점수가 주어진다. 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.

 

출력 :

각 케이스마다 한 줄씩 평균을 넘는 학생들의 비율을 반올림하여 소수점 셋째 자리까지 출력한다.

import java.util.*;

public class Main{
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int c = scan.nextInt();

		for (int j = 1; j <= c; j++) {
			int n = scan.nextInt();
			int[] score = new int[n + 1];
			int sum = 0;
			double avg = 0;
			
			for (int i = 1; i <= n; i++) {
				score[0] = n;
				score[i] = scan.nextInt();
				sum += score[i];
			}
			avg = (double) sum / n;

			int high = 0;
			for (int i = 1; i <= n; i++) {
				if (score[i] > avg) {
					high++;
				}
			}
			System.out.printf("%.3f", 100.0 * high / n);
			System.out.println("%");
		}
		scan.close();
	}
}

'Study > BEAKJOON Algorithm' 카테고리의 다른 글

7단계 문자열  (0) 2020.01.03
6단계 함수  (0) 2019.12.30
4단계 while문  (0) 2019.12.20
3단계 for문  (0) 2019.12.20
2단계 if문  (0) 2019.12.13