just inside

[백준] Silver 5. 10814 - 나이순 정렬 python 본문

coding test/정렬

[백준] Silver 5. 10814 - 나이순 정렬 python

방울도마도 2024. 7. 15. 12:46
728x90

문제 링크

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


문제 설명

온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 작성하시오.

 

입력

첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 ≤ N ≤ 100,000)

둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다. 나이는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고, 이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다. 입력은 가입한 순서로 주어진다.

 

출력

첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순, 나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력한다.


제출 코드

import sys

input = sys.stdin.readline

n = int(input().rstrip())
members = []

for i in range(n):
    members.append([i, *input().split()])

members.sort(key=lambda x: (int(x[1]), x[0]))

for member in members:
    print(member[1], member[2])

 

풀이

  • 회원들의 정보를 저장할 list 생성 - members
  • 입력은 가입한 순서로 주어지므로, 정보 저장시 인덱스를 함께 저장한다.
  • lambda 함수를 사용하여 두 개의 기준으로 정렬해준다. 이 때, 나이가 str으로 저장되어 있으므로 형 변환을 해준다.

 

 

알아둘 사항

  • input().split() 하면 리스트가 생성되므로, *를 사용해 압축해제하여 하나의 리스트에 함께 저장한다.
  • lambda 함수에서 두 개 이상의 기준으로 정렬 시 하나의 튜플로 묶어줘야 한다. 안 묶어 주면 에러 발생함.
728x90