103. 성적이 낮은 순서로 학생 출력하기

아현·2021년 6월 27일
0

Algorithm

목록 보기
103/400
  • N명의 학생 정보가 있다.

    학생 정보는 학생의 이름과 학생의 성적으로 구분된다. 각 학생의 이름과 성적 정보가 주어졌을 때 성적이 낮은 순서대로 학생의 이름을 출력하는 프로그램을 작성하시오.


  • 입력조건

    • 첫 번째 줄에 학생의 수 N이 입력된다. (1 ≤ N ≤ 100,000)

    • 두 번째 줄부터 N + 1번째 줄에는 학생의 이름을 나타내는 문자열 A와 학생의 성적을 나타내는 정수 B가 공백으로 구분되어 입력된다.

      • 문자열 A의 길이와 학생의 성적은 100 이하의 자연수이다.

  • 출력조건

    • 모든 학생의 이름을 성적이 낮은 순서대로 출력한다.

      • 성적이 동일한 학생들의 순서는 자유롭게 출력해도 괜찮다.



키를 이용한 정렬



n = int(input())

array = []
for i in range(n):
  input_data = input().split()

  #이름은 문자열 그대로, 점수는 정수형으로 변환하여 저장
  array.append((input_data[0], int(input_data[1])))

#키(Key)를 이용하여, 점수를 기준으로 정렬
array = sorted(array, key = lambda student: student[1])

for student in array:
  print(student[0], end=' ')



  • 학생의 정보가 최대 100,000개까지 입력될 수 있으므로 최악의 경우 O(NlogN)을 보장하는 알고리즘을 이용하거나 O(N)을 보장하는 계수 정렬을 이용하면 된다.

  • 입력되는 데이터는 학생의 이름과 점수지만 출력할 때는 학생의 이름만 출력하면 되므로 학생 정보를 (점수, 이름)으로 묶은 뒤에 점수를 기준으로 정렬을 수행해야 한다.

profile
Studying Computer Science

0개의 댓글