문제 링크
https://www.acmicpc.net/problem/10814
문제
온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다.
이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이
앞에 오는 순서로 정렬하는 프로그램을 작성하시오.
- 시간 제한 : 3초
- 메모리 제한 : 256MB
입력
첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 ≤ N ≤ 100,000)
둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다.
나이는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고,
이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다.
입력은 가입한 순서로 주어진다.
출력
첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순,
나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력한다.
예제
입력
3
21 Junkyu
21 Dohyun
20 Sunyoung
출력
20 Sunyoung
21 Junkyu
21 Dohyun
정답 및 풀이
import sys
n = int(sys.stdin.readline())
arr = []
for i in range(n):
age, name = input().split()
arr.append([int(age), name])
arr.sort(key=lambda x: x[0])
for i in range(len(arr)):
print(*arr[i])
- import sys
- 많은 입력을 빠르게 처리하기 위해 사용
- sys.stdin.readline()이 input()보다 빠르다.
- n = int(sys.stdin.readline())
- 회원 수(입력 개수)를 입력받는다.
- arr = []
- 회원 정보를 담을 리스트 선언.
- for i in range(n): age, name = input().split()
- 한 줄에 “나이 이름” 형태로 입력받음
- 나이는 정수형으로 변환, 이름은 문자열로 저장
- arr.append([int(age), name])
- 회원 정보를 2차원 리스트 형태로 저장
- arr.sort(key=lambda x: x[0])
- 정렬 기준을 나이(x[0]) 기준으로 설정
- lambda는 익명 함수로, 정렬 시 간단히 기준을 지정할 때 사용
- Python의 정렬은 안정 정렬(Stable Sort) → 같은 나이는 입력 순서 유지됨
- for i in range(len(arr)): print(*arr[i])
- arr[i]는 리스트를 풀어서 출력
'백준' 카테고리의 다른 글
| [백준] 10815 : 숫자카드 (Python/파이썬) (0) | 2025.11.02 |
|---|---|
| [백준] 18870 : 좌표 압축 (Python/파이썬) (1) | 2025.10.31 |
| [백준] 1181 : 단어 정렬 (Python/파이썬) (0) | 2025.10.31 |
| [백준] 11650 : 좌표 정렬하기 (Python/파이썬) (0) | 2025.10.31 |
| [백준] 11651 : 좌표 정렬하기 2 (Python/파이썬) (0) | 2025.10.31 |