본문 바로가기
코딩테스트 문제풀이(Python)

백준 5800번 문제풀이 (파이썬)

by chanfficial 2022. 5. 24.

5800. 성적 통계

 

 

한상덕은 이번에 중덕 고등학교에 새로 부임한 교장 선생님이다. 교장 선생님으로서 첫 번째 일은 각 반의 수학 시험 성적의 통계를 내는 일이다.
중덕 고등학교 각 반의 학생들의 수학 시험 성적이 주어졌을 때, 최대 점수, 최소 점수, 점수 차이를 구하는 프로그램을 작성하시오.

 

 

 

입력 : 첫째 줄에 중덕 고등학교에 있는 반의 수 K (1 ≤ K ≤ 100)가 주어진다. 다음 K개 줄에는 각 반의 학생수 N (2 ≤ N ≤ 50)과 각 학생의 수학 성적이 주어진다. 시험 성적은 0보다 크거나 같고, 100보다 작거나 같은 정수이고, 공백으로 나누어져 있다. 

출력 : 각 반에 대한 출력은 다음과 같이 두 줄로 이루어져 있다.

  • 첫째 줄에는 "Class X"를 출력한다. X는 반의 번호이며 입력으로 주어진 순서대로 1부터 증가한다.
  • 둘째 줄에는 가장 높은 점수, 낮은 점수, 성적을 내림차순으로 정렬했을 때 가장 큰 인접한 점수 차이를 예제 출력과 같은 형식으로 출력한다.

 

ex)

입력 :

2
5 30 25 76 23 78
6 25 50 70 99 70 90

출력 :

Class 1
Max 78, Min 23, Largest gap 46
Class 2
Max 99, Min 25, Largest gap 25

 

 

 

 

 

풀이

k = int(input())

for i in range(k):
    count = list(map(int, input().split()))
    count = count[1:]
    count.sort(reverse=True)
    dif = []
    print('Class ' + str(i+1))
    for i in range(len(count)-1):
        dif.append(count[i] - count[i+1])
    print('Max ' + str(max(count)) + ', ' + 'Min ' + str(min(count)) + ', '
          + 'Largest gap ' + str(max(dif)))

- 먼저 입력받은 반의 수 만큼 반복하며 각 반의 학생 수와 성적을 입력받아 count 리스트를 생성했다. 이때 count 리스트의 0번째 요소는 성적과 무관한 학생 수를 나타내기 때문에 슬라이스를 사용하여 count 리스트에서 삭제했다.

그런 다음 sort(reverse=True) 를 사용하여 count 리스트를 내림차순으로 정렬하였고, 인접한 성적들의 점수 차이를 저장할 dif 리스트를 생성했다.

첫째 줄에 반을 출력한 다음(문자열과 함께 출력하려면 정수형인 i+1을 문자열로 변환해야 함) 반복문을 사용하여 인접한 성적들의 점수 차이를 dif 리스트에 추가했다. 

최종적으로 max()와 min()을 사용하여 가장 높은 점수와 낮은 점수를 출력했고, 마찬가지로 max()를 사용하여 dif 리스트에서 가장 큰 수(=인접한 성적들의 점수 차이가 가장 큰것)를 출력하게 했다.