본문 바로가기
Study (etc)/Problem Solving

[BOJ / C++] 9076번 : 점수 집계

by Haren 2022. 3. 27.

문제

한국 체조협회에서는 심판의 오심을 막기 위하여 점수 집계 시스템을 고치기로 하였다. 이전에는 5명의 심판이 1점부터 10점까지 정수의 점수를 주면 최고점과 최저점을 하나씩 제외한 점수의 합을 총점으로 하였다. 이를 보완하기 위해서 최고점과 최저점을 뺀 나머지 3명 점수의 최고점과 최저점의 차이가 4점 이상 나게 되면 점수 조정을 거쳐서 다시 점수를 매기려고 한다. 점수를 집계하여 총점을 계산하거나, 점수 조정을 거쳐서 다시 점수를 매기려고 하는 경우에는 총점 대신 KIN(Keep In Negotiation)을 출력하는 프로그램을 작성하시오.

입력

입력의 첫 줄에는 테스트 케이스의 개수 T(1 ≤ T ≤ 10)가 주어진다. 각 테스트 케이스는 한 줄에 다섯 심판이 준 점수 다섯 개의 정수 Ni(1 ≤ Ni ≤ 10, i = 1, 2, ..., 5)가 하나의 공백을 사이에 두고 주어진다.

출력

각 테스트 케이스에 대해서 총점을 한 줄씩 출력한다. 만일 점수 조정을 거쳐서 다시 점수를 매기려고 하는 경우에는 총점 대신 KIN을 출력한다.

Solved.ac 레벨

브론즈 II

풀이

#include <bits/stdc++.h>

using namespace std;

int main(){
    ios::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);

    int testCase;
    cin >> testCase;

    for(int i = 0; i < testCase; i++){
        vector<int> scoreArray;
        int sum = 0;

        for(int j = 0; j < 5 ; j++){
            int score = 0;
            cin >> score;
            scoreArray.push_back(score);
        }

        sort(scoreArray.begin(), scoreArray.end());
        scoreArray.erase(scoreArray.begin() + 0);
        scoreArray.erase(scoreArray.end() - 1);

        int maxScore = *max_element(scoreArray.begin(), scoreArray.end());
        int minScore = *min_element(scoreArray.begin(), scoreArray.end());

        if (maxScore - minScore >= 4) {
            cout << "KIN" << endl;
        } else{
            sum = scoreArray[0] + scoreArray[1] + scoreArray[2];
            cout << sum << endl;
        }
    }
    return 0;
}

https://acmicpc.net/problem/9076