본문 바로가기
알고리즘

[BAEKJOON] 25206 너의 평점은

by mAlfred 2023. 11. 7.
반응형
 
  • 문제

    인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 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)

 

반응형