백준 25206 - 너의 평점은 [Rust]

[Silver V] 너의 평점은 - 25206

Posted by Hebi on April 5, 2023

백준 알고리즘

[Silver V] 너의 평점은 - 25206

문제 링크

성능 요약

메모리: 13204 KB, 시간: 4 ms

분류

수학, 구현, 문자열

문제 설명

인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 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줄에 걸쳐 치훈이가 수강한 전공과목의 과목명, 학점, 등급이 공백으로 구분되어 주어진다.

출력

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

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

Code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
use std::collections::HashMap;
use std::io;

fn main() {
    let mut mp: HashMap<&str, f64> = HashMap::new();
    mp.insert("A+", 4.5);
    mp.insert("A0", 4.0);
    mp.insert("B+", 3.5);
    mp.insert("B0", 3.0);
    mp.insert("C+", 2.5);
    mp.insert("C0", 2.0);
    mp.insert("D+", 1.5);
    mp.insert("D0", 1.0);
    mp.insert("F", 0.0);

    let mut result: f64 = 0.0;
    let mut score_sum: f64 = 0.0;

    for _ in 0..20 {
        let mut input = String::new();
        io::stdin().read_line(&mut input).expect("Failed to read line");
        let tokens: Vec<&str> = input.split_whitespace().collect();
        let name = tokens[0];
        let score: f64 = tokens[1].parse().expect("Failed to parse score");
        let grade = tokens[2];
        if grade == "P" {
            continue;
        }
        result += score * mp.get(grade).unwrap();
        score_sum += score;
    }
    result /= score_sum;

    println!("{:.4}", result);
}