mun dev

[백준] 25206 너의 평점은 자바(Java) 본문

알고리즘/백준

[백준] 25206 너의 평점은 자바(Java)

mndev 2023. 4. 20. 15:38

문제설명

인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 3.3 이상이거나 졸업고사를 통과해야 한다. 그런데 아뿔싸, 치훈이는 깜빡하고 졸업고사를 응시하지 않았다는 사실을 깨달았다!

치훈이의 전공평점을 계산해주는 프로그램을 작성해보자.

전공평점은 전공과목별 (학점 × 과목평점)의 합을 학점의 총합으로 나눈 값이다.

인하대학교 컴퓨터공학과의 등급에 따른 과목평점은 다음 표와 같다.

 

A+ 4.5
A0 4.0
B+ 3.5
B0 3.0
C+ 2.5
C0 2.0
D+ 1.5
D0 1.0
F 0.0

P/F 과목의 경우 등급이 P또는 F로 표시되는데, 등급이 P인 과목은 계산에서 제외해야 한다.

과연 치훈이는 무사히 졸업할 수 있을까?

 

입력

20줄에 걸쳐 치훈이가 수강한 전공과목의 과목명, 학점, 등급이 공백으로 구분되어 주어진다.

 

출력

치훈이의 전공평점을 출력한다.

정답과의 절대오차 또는 상대오차가 10−4 이하이면 정답으로 인정한다.

 

제한

  • 1 ≤ 과목명의 길이 ≤ 50
  • 과목명은 알파벳 대소문자 또는 숫자로만 이루어져 있으며, 띄어쓰기 없이 주어진다. 입력으로 주어지는 모든 과목명은 서로 다르다.
  • 학점은 1.0,2.0,3.0,4.0중 하나이다.
  • 등급은 A+,A0,B+,B0,C+,C0,D+,D0,F,P중 하나이다.
  • 적어도 한 과목은 등급이 P가 아님이 보장된다.

 

 

✅ 통과한 코드 

import java.util.*;
import java.io.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st;
        double scoreNum[] = {4.5, 4.0, 3.5, 3.0, 2.5, 2.0, 1.5, 1.0, 0.0};
        String score[] = {"A+", "A0", "B+", "B0", "C+", "C0", "D+", "D0", "F"};
        String str[]=new String[20];

        double result=0;
        double scoreSum=0;
        for (int i = 0; i < 20; i++) {
            str[i]=br.readLine();
            st= new StringTokenizer(str[i]," ");

            String subject = st.nextToken();
            double num = Double.parseDouble(st.nextToken());
            String grade = st.nextToken();

            for(int j=0; j<score.length; j++){
                if(grade.equals(score[j])){
                    result+=(num*scoreNum[j]);
                    if(j!=9){
                        scoreSum+=num;
                    }
                }
            }
        }

       result/=scoreSum;
        System.out.printf("%.6f\n",result);
    }
}