이 알고리즘 문제는 인프런의 자바(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보다 앞에 오도록 한다.