카테고리 없음

[Baekjoon 25206] 너의 평점은 - JAVA

planting grass 2023. 11. 5. 14:28
728x90

[Silver V] 너의 평점은 - 25206

문제 링크

성능 요약

메모리: 14640 KB, 시간: 136 ms

분류

구현, 수학, 문자열

제출 일자

2023년 11월 5일 13:53:33

문제 설명

인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 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}\) 이하이면 정답으로 인정한다.

문제 풀이

변수 자료형만 신경쓰면 그리 어렵지 않은 문제다.

스위치로 노가다해서 풀어도 상관은 없다.

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

        double totalGradePoints = 0;
        double totalCredits = 0;
        String gradeList[] = {"A+", "A0", "B+", "B0", "C+", "C0", "D+", "D0", "F", "P"};
        double gradePoints[] = {4.5, 4.0, 3.5, 3.0, 2.5, 2.0, 1.5, 1.0, 0.0, 0.0};

        for (int i = 0; i < 20; i++) {
            StringTokenizer st = new StringTokenizer(br.readLine());
            String subject = st.nextToken();
            double credits = Double.parseDouble(st.nextToken());
            String grade = st.nextToken();

            for (int j = 0; j < 10; j++) {
                if (grade.equals(gradeList[j])) {
                    totalGradePoints += credits * gradePoints[j];
                    if (j != 9) {
                        totalCredits += credits;
                    }
                }
            }
        }

        double averageGPA = totalGradePoints / totalCredits;
        System.out.printf("%.6f\n", averageGPA);
    }
}

코드 풀이

double totalGradePoints = 0;
double totalCredits = 0;
String gradeList[] = {"A+", "A0", "B+", "B0", "C+", "C0", "D+", "D0", "F", "P"};
double gradePoints[] = {4.5, 4.0, 3.5, 3.0, 2.5, 2.0, 1.5, 1.0, 0.0, 0.0};
  • totalGradePoints: 각 과목의 학점에 해당하는 점수를 합하여 총 학점 점수를 저장하는 변수
  • totalCredits: 학점의 총합을 저장할 변수
  • gradeList: 가능한 학점 목록을 저장할 배열
  • gradePoints: 학점에 대응하는 점수를 저장한 배열
for (int i = 0; i < 20; i++) {
    StringTokenizer st = new StringTokenizer(br.readLine());
    String subject = st.nextToken();
    double credits = Double.parseDouble(st.nextToken());
    String grade = st.nextToken();
  • 반복문을 입력에 사용하기 위해 20번 반복
  • subject: 각 과목의 이름을 저장할 변수
  • credits: 각 과목의 학점을 저장할 변수
  • grade: 각 과목의 학점 문자열을 저장할 변수
for (int j = 0; j < 10; j++) {
    if (grade.equals(gradeList[j])) {
        totalGradePoints += credits * gradePoints[j];
        if (j != 9) {
            totalCredits += credits;
        }
    }
}
  • 이중 반복문으로 gradeList를 순회하고, 현재 학점과 목록의 학점을 비교하여 일치하는 경우 해당 학점에 해당하는 gradePoints를 곱하고, totalCreditstotalGradePoints에 누적한다.
double averageGPA = totalGradePoints / totalCredits;
System.out.printf("%.6f\n", averageGPA);
  • 총 학점 점수를 총 학점으로 나누어 평균 GPA를 계산하고, 결과를 소수점 6자리까지 출력한다.
728x90