반응형
# Problem
|
온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 작성하시오. 입력첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 ≤ N ≤ 100,000) 둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다. 나이는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고, 이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다. 입력은 가입한 순서로 주어진다. 출력첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순, 나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력한다. ![]() |
# My Answer - sort() 활용
n = int(input())
result=[]
for i in range(n):
a,b = input().split()
result.append([i,int(a),b])
result.sort(key = lambda x : (x[1],x[0]))
for i in result:
print(i[1],i[2])
# Solution 1 - sorted 함수 활용
n = int(input())
array = []
for _ in range(n):
input_data = input().split(' ')
array.append((int(input_data[0]), input_data[1]))
array = sorted(array, key=lambda x: x[0])
for i in array:
print(i[0], i[1])
첫번째 원소 기준으로 정렬하고 나머지는 원래 들어온 순서대로 정렬됨
반응형
'Algorithm > 백준 알고리즘 풀이' 카테고리의 다른 글
| [Baekjoon] 10989. 수 정렬하기 3 ( 계수 정렬 ) (0) | 2021.04.19 |
|---|---|
| [Baekjoon] 11650. 좌표 정렬하기 (0) | 2021.04.19 |
| [Baekjoon] 1427. 소트인사이드 (0) | 2021.04.19 |
| [Baekjoon] 2750. 수 정렬하기, 2751. 수 정렬하기 2 (0) | 2021.04.19 |
| ❗️[Baekjoon] 4195. 친구 네트워크 (0) | 2021.04.15 |
