반응형
-
문제
인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 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번째에 입력된 등급을 계산하면 되는 문제였다.
그리고 추가로 실수 형태로 받고 있기 때문에 데이터 타입만 신경써서 계산한다면 쉽게 풀 수 있는 문제였음.
import sys
jum = 0.0
vv = 0.0
for _ in range(20):
tmp = sys.stdin.readline().strip().split()
st = tmp[0]
v = float(tmp[1])
s = tmp[2]
if s == "P":
pass
elif s == "A+":
jum += (4.5*v)
vv += v
elif s == "A0":
jum += (4.0*v)
vv += v
elif s == "B+":
jum += (3.5*v)
vv += v
elif s == "B0":
jum += (3.0*v)
vv += v
elif s == "C+":
jum += (2.5*v)
vv += v
elif s == "C0":
jum += (2.0*v)
vv += v
elif s == "D+":
jum += (1.5*v)
vv += v
elif s == "D0":
jum += (1.0*v)
vv += v
else:
jum += (0.0*v)
vv += v
print(jum/vv)
반응형
'알고리즘' 카테고리의 다른 글
[BAEKJOON] 2566 최댓값 (0) | 2023.11.08 |
---|---|
[BAEKJOON] 2738 행렬 덧셈 (0) | 2023.11.07 |
[BAEKJOON] 1316 그룹 단어 체커 (0) | 2023.11.07 |
[BAEKJOON] 2941 크로아티아 알파벳 (0) | 2023.11.07 |
[BAEKJOON] 10988 팰린드롬인지 확인하기 (0) | 2023.11.06 |