문제 링크
https://www.acmicpc.net/problem/25206
문제
인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 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가 아님이 보장된다.
예제
입력
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
-------------
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
출력
3.284483
-------------
0.000000
정답 및 풀이
grade_dict = {
"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
}
total_score = 0.0
total_credit = 0.0
for i in range(20):
subject, credit, grade = input().split()
credit = float(credit)
if grade == "P":
continue
total_score += credit * grade_dict[grade]
total_credit += credit
if total_credit == 0:
print(0.0)
else:
print(total_score / total_credit)
- 딕셔너리 생성
- 변수 초기화(학점 * 평점 합, 학점 합)
- 반복문
- 입력 분리
- 학점 변환 : 문자열 → float
- P 과목 처리
- 학점 누적
- 모든 과목이 P 라면 학점이 0 → 0.0 출력
- 최종 출력
새롭게 배운 내용 및 느낀점
- 딕셔너리
- 중괄호 사용
- key : value
- 값 접근
- dict[키]
- 안전하게 접근 → .get() 사용
- 값 추가/수정
- 새로운 키를 지정하면 추가
- 기존 키를 지정하면 수정
- 값 삭제
- del dict[키]
- 반복
- dict.keys() : 키
- dict.values() : 값
- dict.items() : 키,값
'백준' 카테고리의 다른 글
| [백준] 2566 : 최댓값 (Python/파이썬) (0) | 2025.09.29 |
|---|---|
| [백준] 2738 : 행렬 덧셈 (Python/파이썬) (0) | 2025.09.29 |
| [백준] 1316 : 그룹 단어 체커 (Python/파이썬) (0) | 2025.09.25 |
| [백준] 2941 : 크로아티아 알파벳 (Python/파이썬) (0) | 2025.09.22 |
| [백준] 1157 : 단어 공부 (Python/파이썬) (0) | 2025.09.21 |