familiar-ming 님의 블로그
[Python] 백준 10814_나이순 정렬 본문
문제 확인
나이순 정렬
온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 작성하시오.
입력
첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 ≤ N ≤ 100,000)
둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다. 나이는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고, 이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다. 입력은 가입한 순서로 주어진다.
출력
첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순, 나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력한다.
예제 입력 1
3
21 Junkyu
21 Dohyun
20 Sunyoung
예제 출력 1
20 Sunyoung
21 Junkyu
21 Dohyun
풀이
[1] 내가 작성한 코드
import sys
input = sys.stdin.readline
def solution(people):
people.sort(key = lambda v : v[0])
result = []
for x in people:
result.append(f'{x[0]} {x[1]}')
return '\n'.join(result)
N = int(input().strip())
people = []
for i in range(N):
age, name = input().strip().split() # 입력받은 값을 분리
people.append([int(age), name]) # 나이는 int로 변환, 이름은 문자열 그대로
print(solution(people))
- 두 개 이상의 변환이 필요한 경우 입력 방법 (각 요소에 대해 개별적으로 처리하여 추가하기)
배열 안에 배열로 입력값을 받으려 할 때 기존 map 함수를 이용했던 것과 달리 다른 방법을 배웠다.
map 함수는 모든 요소에 동일한 함수를 적용하기 때문에 각 요소별로 다른 타입을 주는 것이 불가능하다.
- f 스트링을 이용하면 배열 요소를 문자열로 쉽게 바꿀 수 있다!
[2] 다른 풀이
def solution(member):
member.sort(key = lambda v : (v[0]))
for x in member:
print(x[0], x[1])
n = int(input())
arr = []
for i in range(n):
a, b = input().split()
a = int(a)
arr.append([a, b])
solution(arr)
- 위의 코드보다 훨씬 간결하다. 하지만 함수 내에서 print()를 반복하는 건 되도록 하지 말라고
다른 친구에게 배웠기에, 반복 print() 를 하지 않는 식으로 작성하려 한다.
배움
Q.
만약 입력값으로 숫자와 문자열이 담긴 리스트가 아니라, 문자열로만 이루어진 리스트를 받으면
숫자 기준으로 오름차순 정렬이 될까?
A.
No ! 정렬이 제대로 안된다. 작은 수의 경우 되는 것처럼 보이는 것이다.
이유는 파이썬에서 문자열은 사전식 순서로 정렬되기 때문에
문자열이 되어 있는 숫자들이라도 문자열의 알파벳 순서처럼 정렬된다.
문자열끼리의 비교는 첫 번째 문자부터 차례대로 비교하는 방식으로 이루어진다.
ex. '100'과 '99'가 있을 때, (문자열 100과 문자열 99의 비교)
'1'이 '9'보다 작으므로 '100'이 '99'보다 먼저 앞에 나온다.
따라서 숫자처럼 정확한 숫자 정렬을 원한다면, 입력을 받을 때 정수로 변환해야 한다!
'알고리즘 > 문제(백준 | 기타)' 카테고리의 다른 글
[Python] 인프런 강의_검정색 영역구하기(DFS) (8) | 2024.09.19 |
---|---|
[Python] 백준 1110_더하기 사이클 (3) | 2024.09.13 |