-
Notifications
You must be signed in to change notification settings - Fork 25
/
P28_1.java
39 lines (33 loc) · 1.34 KB
/
P28_1.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package ch10;
import java.util.Comparator;
import java.util.PriorityQueue;
public class P28_1 {
// 거리와 좌표를 보관할 Point 클래스 선언
static class Point {
double distance;
int[] point;
// 거리와 좌표를 파라미터로 받는다.
public Point(double distance, int[] point) {
this.distance = distance;
this.point = point;
}
}
public int[][] kClosest(int[][] points, int k) {
// Point 클래스를 저장하는 우선순위 큐로, 정렬 기준은 distance로 한다.
PriorityQueue<Point> pq = new PriorityQueue<>(Comparator.comparingDouble(a -> a.distance));
// 파라미터로 받은 좌표 목록 순회
for (int[] point : points) {
// 유클리드 거리 계산
double distance = Math.sqrt((long) point[0] * point[0] + (long) point[1] * point[1]);
// 우선순위 큐에 거리와 좌표를 Point 클래스로 담아 삽입
pq.add(new Point(distance, point));
}
int[][] results = new int[k][];
// k번만큼 반복하여 결과 추출
for (int i = 0; i < k; i++) {
// 우선순위 큐에서 추출한 Point 클래스의 좌표(point)를 결과로 삽입
results[i] = pq.poll().point;
}
return results;
}
}