백준 알고리즘
[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줄에 걸쳐 치훈이가 수강한 전공과목의 과목명, 학점, 등급이 공백으로 구분되어 주어진다.
출력
치훈이의 전공평점을 출력한다.
정답과의 절대오차 또는 상대오차가
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);
}