반응형
[문제]
N명의 학생 정보가 있다. 학생 정보는 학생의 이름과 학생의 성적으로 구분된다. 각 학생의 이름과 성적 정보가 주어졌을 때 성적이 낮은 순서대로 학생의 이름을 출력하는 프로그램을 작성하시오.
[입력 조건]
- 첫 번째 줄에 학생의 수 N이 입력된다. (1 <= N <= 100,000)
- 두 번째 줄부터 N + 1 번째 줄에는 학생의 이름을 나타내는 문자열 A와 학생의 성적을 나타내는 정수 B가 공백으로 구분되어 입력된다. 문자열 A의 길이와 학생의 성적은 100 이하의 자연수이다.
[출력 조건]
- 모든 학생의 이름을 성적이 낮은 순서대로 출력한다. 성적이 동일한 학생들의 순서는 자유롭게 출력해도 괜찮다.
[입력 예시]
2
홍길동 95
이순신 77
[출력 예시]
이순신 홍길동
[문제 해설]
- 학생의 정보가 최대 100,000개 까지 입력될 수 있으므로 최악의 경우 O(NlogN)을 보장하는 알고리즘을 이용하거나, O(N)을 보장하는 계수 정렬을 이용하면 됨.
- 입력 데이터는 학생의 이름과 점수지만, 출력할떄는 학생의 이름만 출력하기에 학생 정보를 (점수, 이름)으로 묶은 뒤에 점수를 기준으로 정렬을 수행해야 함.
- 파이썬 기본 정렬 라이브러리를 사용하는 것이 효과적임.
[소스코드]
# N을 입력받기
n = int(input())
# N명의 학생 정보를 입력받아 리스트에 저장
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=' ')
반응형
'알고리즘 Study > 이코테' 카테고리의 다른 글
| [07이진탐색] 순차 탐색 (p186~p191) (0) | 2025.11.30 |
|---|---|
| [06정렬] 실전 문제-두 배열의 원소 교체 (p182~p184) (0) | 2025.11.26 |
| [06정렬] 실전문제-위에서 아래로 (p178~p179) (0) | 2025.11.26 |
| [06정렬] 파이썬 정렬 라이브러리 (p175 ~ p177) (0) | 2025.11.26 |
| [06정렬] 6-6 계수 정렬 (p171 ~ p174) (0) | 2025.11.26 |