기록하는삶

[코딩 테스트 연습(파이썬/Python)] 백준 2108번 _ 통계학 본문

백준(Python)/구현(implementation)

[코딩 테스트 연습(파이썬/Python)] 백준 2108번 _ 통계학

mingchin 2021. 12. 2. 18:15
728x90
반응형

https://www.acmicpc.net/problem/2108

 

2108번: 통계학

첫째 줄에 수의 개수 N(1 ≤ N ≤ 500,000)이 주어진다. 단, N은 홀수이다. 그 다음 N개의 줄에는 정수들이 주어진다. 입력되는 정수의 절댓값은 4,000을 넘지 않는다.

www.acmicpc.net

[문제]

수를 처리하는 것은 통계학에서 상당히 중요한 일이다. 통계학에서 N개의 수를 대표하는 기본 통계값에는 다음과 같은 것들이 있다. 단, N은 홀수라고 가정하자.

  1. 산술평균 : N개의 수들의 합을 N으로 나눈 값
  2. 중앙값 : N개의 수들을 증가하는 순서로 나열했을 경우 그 중앙에 위치하는 값
  3. 최빈값 : N개의 수들 중 가장 많이 나타나는 값
  4. 범위 : N개의 수들 중 최댓값과 최솟값의 차이

N개의 수가 주어졌을 때, 네 가지 기본 통계값을 구하는 프로그램을 작성하시오.

 

[입력]

첫째 줄에 수의 개수 N(1 ≤ N ≤ 500,000)이 주어진다. 단, N은 홀수이다. 그 다음 N개의 줄에는 정수들이 주어진다. 입력되는 정수의 절댓값은 4,000을 넘지 않는다.

[출력]

첫째 줄에는 산술평균을 출력한다. 소수점 이하 첫째 자리에서 반올림한 값을 출력한다.

둘째 줄에는 중앙값을 출력한다.

셋째 줄에는 최빈값을 출력한다. 여러 개 있을 때에는 최빈값 중 두 번째로 작은 값을 출력한다.

넷째 줄에는 범위를 출력한다.

 

[아이디어]

1) collections의 Counter를 이용하자.

2) input()으로 입력받으면 시간초과가 난다.

3) 셋 째줄에 대한 조건만 조심하면 될 것 같다.

 

import sys
from collections import Counter
n = int(input())
a = sorted([int(sys.stdin.readline().strip()) for _ in range(n)])
print(round(sum(a)/(l:=len(a))))
print(a[l//2])
s = sorted((Counter(a).items()), key = lambda x: (-x[1], x[0]))
if (len(s) == 1):
    print(s[0][0])
elif s[0][1] != s[1][1]:
    print(s[0][0])
else: print(s[1][0])
print(a[-1] - a[0])
728x90
반응형