BOJ 18110 - Solved.Ac (Python)

조민수·2024년 2월 1일
0

BOJ

목록 보기
4/64

S4, 구현


문제 설명

어떤 문제의 난이도는 그 문제를 푼 사람들이 제출한 난이도 의견을 바탕으로 결정한다. 난이도 의견은 그 사용자가 생각한 난이도를 의미하는 정수 하나로 주어진다. solved.ac가 사용자들의 의견을 바탕으로 난이도를 결정하는 방식은 다음과 같다.

  • 아직 아무 의견이 없다면 문제의 난이도는 0으로 결정한다.
  • 의견이 하나 이상 있다면, 문제의 난이도는 모든 사람의 난이도 의견의 30% 절사평균으로 결정한다.

절사평균이란 극단적인 값들이 평균을 왜곡하는 것을 막기 위해 가장 큰 값들과 가장 작은 값들을 제외하고 평균을 내는 것을 말한다. 30% 절사평균의 경우 위에서 15%, 아래에서 15%를 각각 제외하고 평균을 계산한다. 따라서 20명이 투표했다면, 가장 높은 난이도에 투표한 3명과 가장 낮은 난이도에 투표한 3명의 투표는 평균 계산에 반영하지 않는다는 것이다.

제외되는 사람의 수는 위, 아래에서 각각 반올림한다. 25명이 투표한 경우 위, 아래에서 각각 3.75명을 제외해야 하는데, 이 경우 반올림해 4명씩을 제외한다.

마지막으로, 계산된 평균도 정수로 반올림된다. 절사평균이 16.7이었다면 최종 난이도는 17이 된다.

사용자들이 어떤 문제에 제출한 난이도 의견 목록이 주어질 때, solved.ac가 결정한 문제의 난이도를 계산하는 프로그램을 작성하시오.

입력

첫 번째 줄에 난이도 의견의 개수 n이 주어진다. (0 ≤ n ≤ 3 × 105)

이후 두 번째 줄부터 1 + n번째 줄까지 사용자들이 제출한 난이도 의견 n개가 한 줄에 하나씩 주어진다. 모든 난이도 의견은 1 이상 30 이하이다.

출력

solved.ac가 계산한 문제의 난이도를 출력한다.

입력 예시

5
1
5
5
7
8

출력 예시

6

풀이

  • Python의 round는 사사오입이 아닌 오사오입 방식
    -> round(2.5) == 2, round(3.5) == 4

따라서, round()를 쓰는게 아닌 int(값 + 0.5)를 통해 해결해야 했다.

from sys import stdin
n = int(stdin.readline())
arr = []
for i in range(n):
    arr.append(int(stdin.readline().rstrip()))

if n == 0:
    print(0)
    exit()

arr.sort()
k = int((n * 0.15) + 0.5)
arr = arr[k : n-k]
avg = int((sum(arr) / len(arr)) + 0.5)
print(avg)

오사오입임을 몰라서 도대체 뭐가 문제지 하고 한참 봤다...

profile
사람을 좋아하는 Front-End 개발자

0개의 댓글