[Python] 백준알고리즘 #10814

r1verfuture·2022년 2월 1일
0

백준알고리즘

목록 보기
109/110

📝 문제

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

⌨️ 입력

첫째 줄에 온라인 저지 회원의 수 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()); infos = []
for _ in range(n):
    info = sys.stdin.readline().split()
    infos.append((int(info[0]), info[1]))
infos.sort(key = lambda i : i[0])
for i in infos:
    print(str(i[0]) + ' ' + i[1])

✏️ 내가 제출한 코드에 대한 설명

  • 순서대로 입력된 정보를 '(age, name)'의 형태인 Tuple로 저장한 다음 lambda로 정렬해서 출력하는 방식이다.
  • sys.stdin.readline() : 키보드로 입력한 값을 받는 함수 (기존의 input() 보다 속도가 훨씬 빠르다.)
  • range(a) : 0부터 a-1까지의 정수를 반환하는 함수
  • a.split() : a를 빈칸 단위로 쪼개서 반환하는 함수
  • a.sort(key = b) : a를 b라는 기준에 맞게 정렬한다.
  • lambda : 간단한 함수를 입력할 때 사용한다. (주로 한줄짜리 함수)
  • 메모리 : 45488 KB
  • 시간 : 256 ms
  • 코드 길이 : 237 B
profile
#iOS #Swift #Developer #Python

0개의 댓글