728x90

문제
2차원 평면 위의 점 N개가 주어진다. 좌표를 y좌표가 증가하는 순으로, y좌표가 같으면 x좌표가 증가하는 순서로 정렬한 다음 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 점의 개수 N (1 ≤ N ≤ 100,000)이 주어진다. 둘째 줄부터 N개의 줄에는 i번점의 위치 xi와 yi가 주어진다. (-100,000 ≤ xi, yi ≤ 100,000) 좌표는 항상 정수이고, 위치가 같은 두 점은 없다.
출력
첫째 줄부터 N개의 줄에 점을 정렬한 결과를 출력한다.
예시

코드
import sys
n = int(sys.stdin.readline())
n_list = []
for i in range(n):
num = list(map(int, sys.stdin.readline().split()))
t = num[1]
num[1] = num[0]
num[0] = t
n_list.append(num)
n_list.sort()
for i in range(n):
print(n_list[i][1],n_list[i][0])
코드 해석
- 테스트 케이스의 수를 받는다.
- 수들을 받을 n_list를 생성한다.
- for로 수들을 받는다.
- 수를 받는다.
- 두 수의 위치를 바꾼다.
- n_list에 추가한다.
- n_list를 정렬한다.
- 앞 뒤를 바꾸어 출력한다.

728x90
'코딩테스트 > Beakjoon' 카테고리의 다른 글
| 백준 11721번 : 열 개씩 끊어 출력하기 [Python] (0) | 2024.01.20 |
|---|---|
| 백준 11720번 : 숫자의 합 [Python] (0) | 2024.01.20 |
| 백준 11650번 : 좌표 정렬하기 [Python] (0) | 2024.01.20 |
| 백준 11382번 : 꼬마 정민 [Python] (0) | 2024.01.20 |
| 백준 11050번 : 이항 계수 1 [Python] (0) | 2024.01.20 |