이 알고리즘 문제는 인프런의 자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비 (김태원)의 문제입니다.
문제 설명
코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.util.StringTokenizer;
public class sec06_07 {
public static class Point{
private int x;
private int y;
public Point(int x, int y)
{
this.x = x;
this.y = y;
}
}
public static ArrayList<Point> solution(ArrayList<Point> list) {
Collections.sort(list, (a , b) ->{
if (a.x == b.x) return a.y - b.y;
else return a.x - b.x;
});
return list;
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
ArrayList<Point> list = new ArrayList<>();
for(int i = 0; i < N; ++i)
{
StringTokenizer st = new StringTokenizer(br.readLine());
Point newPoint = new Point(Integer.parseInt(st.nextToken()), Integer.parseInt(st.nextToken()));
list.add(newPoint);
}
for (Point point : solution(list)) System.out.println(point.x + " " + point.y);
}
}
설명
- 두 좌표 객체 a와 b의 x 값이 다를 경우, a.x - b.x를 반환하여 x 값이 작은 순서대로 정렬한다.
즉, a.x < b.x이면 a가 b보다 앞에 오도록 한다. - 만약 x 값이 같다면, y 값을 비교하여 y 값이 작은 순서대로 정렬한다.
이는 a.y - b.y를 통해 이루어진다. 예를 들어, a.y < b.y이면 a가 b보다 앞에 오도록 한다.
'자료구조 & 알고리즘 > Inflearn' 카테고리의 다른 글
[인프런 알고리즘] Chapter 6, 9번 문제(뮤직비디오- 결정알고리즘) (0) | 2024.08.23 |
---|---|
[인프런 알고리즘] Chapter 6, 8번 문제(이분검색) (0) | 2024.08.22 |
[인프런 알고리즘] Chapter 6, 6번 문제(장난꾸러기) (0) | 2024.08.20 |
[인프런 알고리즘] Chapter 6, 5번 문제(중복 확인) (0) | 2024.08.18 |
[인프런 알고리즘] Chapter 06, 4번 문제(Least Recently Used) (0) | 2024.08.17 |