이전 시간에 좌표 정렬하기 문제에서 y로 바뀐 것 말고는 바뀐 게 없다.
이번에는 저번 문제에서 인터넷에서 찾아본 아래 코드 방법으로
배열을 정리해보면서 풀어보려고 한다.
Arrays.sort(arr, (e1, e2) -> {
//y값이 같으면 x로 순서 정렬
if(e1[1] == e2[1]) {
return e1[0] - e2[0];
}
//그게 아니면 y로 순서 정렬
return e1[1] - e2[1];
});
좌표 정렬하기 1 문제의 링크이다.
2022.09.09 - [Programing/CodingTest] - CodingTest #24 Java 11650 (좌표 정렬하기) 문제 풀이
저번 문제에서 모델 클래스를 만들어서 풀었다.
물론 코드량이 많아진 게 단점이긴 한데,
이번 방법으로 훨씬 가독성이 좋고,
속도도 어느정도 더 빠른 느낌을 받았다.
게다가 2차원 배열을 사용해서 연습도 하는 시간을 가졌다.
아래 코드가 문제를 푼 코드이다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
public class Test11651 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
StringTokenizer st;
StringBuilder sb = new StringBuilder();
int[][] arr = new int[N][2];
for(int i = 0; i < N; i++) {
st = new StringTokenizer(br.readLine(), " ");
int x = Integer.parseInt(st.nextToken());
int y = Integer.parseInt(st.nextToken());
arr[i][0] = x;
arr[i][1] = y;
}
Arrays.sort(arr, (e1, e2) -> {
//y값이 같으면 x로 순서 정렬
if(e1[1] == e2[1]) {
return e1[0] - e2[0];
}
//그게 아니면 y로 순서 정렬
return e1[1] - e2[1];
});
for (int[] ints : arr) {
sb.append(ints[0]).append(" ").append(ints[1]).append("\n");
}
System.out.print(sb);
}
}
효율을 위해 StringBuilder도 활용해주자.