문제
인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 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가 아님이 보장된다.
예제 입력 1
ObjectOrientedProgramming1 3.0 A+
IntroductiontoComputerEngineering 3.0 A+
ObjectOrientedProgramming2 3.0 A0
CreativeComputerEngineeringDesign 3.0 A+
AssemblyLanguage 3.0 A+
InternetProgramming 3.0 B0
ApplicationProgramminginJava 3.0 A0
SystemProgramming 3.0 B0
OperatingSystem 3.0 B0
WirelessCommunicationsandNetworking 3.0 C+
LogicCircuits 3.0 B0
DataStructure 4.0 A+
MicroprocessorApplication 3.0 B+
EmbeddedSoftware 3.0 C0
ComputerSecurity 3.0 D+
Database 3.0 C+
Algorithm 3.0 B0
CapstoneDesigninCSE 3.0 B+
CompilerDesign 3.0 D0
ProblemSolving 4.0 P
예제 출력 1
3.284483
예제 입력 2
BruteForce 3.0 F
Greedy 1.0 F
DivideandConquer 2.0 F
DynamicProgramming 3.0 F
DepthFirstSearch 4.0 F
BreadthFirstSearch 3.0 F
ShortestPath 4.0 F
DisjointSet 2.0 F
MinimumSpanningTree 2.0 F
TopologicalSorting 1.0 F
LeastCommonAncestor 2.0 F
SegmentTree 4.0 F
EulerTourTechnique 3.0 F
StronglyConnectedComponent 2.0 F
BipartiteMatching 2.0 F
MaximumFlowProblem 3.0 F
SuffixArray 1.0 F
HeavyLightDecomposition 4.0 F
CentroidDecomposition 3.0 F
SplayTree 1.0 F
예제 출력 2
0.000000
풀이
문자열을 입력 받을 때 " " 기준으로 나눈 후 2번째와 3번째 element를 사용한다.
과목 평점을 알파벳에서 double 형 정수로 변경 & 학점을 전체 학점에 더하기를 한다.
조건문 if에서 P일 경우 continue를 한다.
소스 코드
import java.util.Scanner;
public class p25206 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
double[] credit = new double[20];
double[] grade = new double[20];
double total_score = 0;
double total_credit = 0;
for (int i = 0; i < 20; i++) {
String[] str = scanner.nextLine().split(" ");
credit[i] = Double.valueOf(str[1]);
total_credit += credit[i];
if (str[2].equals("P")) {
total_credit -= credit[i];
continue;
} else if (str[2].equals("A+")) {
grade[i] = 4.5;
} else if (str[2].equals("A0")) {
grade[i] = 4.0;
} else if (str[2].equals("B+")) {
grade[i] = 3.5;
} else if (str[2].equals("B0")) {
grade[i] = 3.0;
} else if (str[2].equals("C+")) {
grade[i] = 2.5;
} else if (str[2].equals("C0")) {
grade[i] = 2.0;
} else if (str[2].equals("D+")) {
grade[i] = 1.5;
} else if (str[2].equals("D0")) {
grade[i] = 1.0;
} else if (str[2].equals("F")) {
grade[i] = 0.0;
}
total_score += credit[i] * grade[i];
}
System.out.println(total_score / total_credit);
scanner.close();
}
}
'알고리즘 > BaekJoon' 카테고리의 다른 글
[백준 / Java] 2750 수 정렬하기 (0) | 2023.10.10 |
---|---|
[백준 / Java] 1546 평균 (0) | 2023.10.03 |
[백준 / Java] 1316 그룹 단어 체커 (0) | 2023.09.30 |
[백준 / Java] 10988 팰린드롬인지 확인하기 (0) | 2023.09.30 |
[백준 / Java] 10824 네 수 (0) | 2023.09.28 |