forked from onlybooks/java-algorithm-interview
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathP44_1.java
55 lines (49 loc) · 2.97 KB
/
P44_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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package ch13;
import java.util.*;
public class P44_1 {
public int networkDelayTime(int[][] times, int n, int k) {
// 네트워크의 각 노드를 출발지 → 도착지 형태의 그래프로 구성
Map<Integer, Map<Integer, Integer>> graph = new HashMap<>();
for (int[] time : times) {
// 값이 존재하지 않을 경우 빈 해시맵 생성
graph.putIfAbsent(time[0], new HashMap<>());
// 출발지에 (도착지, 소요 시간) 추가
graph.get(time[0]).put(time[1], time[2]);
}
// 우선순위 큐 생성, 값이 (도착지, 소요 시간)으로 구성되므로, 정렬 기준은 도착지(key)와 소요 시간(value) 중 소요 시간을 기준으로 한다.
Queue<Map.Entry<Integer, Integer>> pq = new PriorityQueue<>(Map.Entry.comparingByValue());
// (도착지, 소요 시간)을 큐에 삽입, 시작은 출발지 k이며, 소요 시간은 출발지이므로 당연히 0이다.
pq.add(new AbstractMap.SimpleEntry<>(k, 0));
// (도착지, 소요 시간) 최종 결과를 저장하는 변수 선언
Map<Integer, Integer> dist = new HashMap<>();
// 큐에 값이 남아 있다면 없어질 때 까지 반복
while (!pq.isEmpty()) {
// 소요 시간이 가장 빠른 값 추출
Map.Entry<Integer, Integer> cur = pq.poll();
// 우선순위 큐의 항목이 Map.Entry이므로 순회 과정 없의 간단히 getKey(), getValue()로 (도착지, 소요 시간)을 조회할 수 있다.
int u = cur.getKey();
int dist_u = cur.getValue();
// u 지점까지의 소요 시간이 아직 계산되지 않았다면 처리 시작
if (!dist.containsKey(u)) {
// u 지점까지의 소요 시간(dist_u)을 결과 변수에 삽입
dist.put(u, dist_u);
// u 지점을 출발지로 한 경로가 있다면 처리 시작
if (graph.containsKey(u)) {
// u 지점을 출발지로 한 모든 경로 순회
for (Map.Entry<Integer, Integer> v : graph.get(u).entrySet()) {
// u 지점까지의 소요 시간(dist_u) + u 지점을 출발지로 한 도착지까지 소요 시간
int alt = dist_u + v.getValue();
// 우선순위 큐에 (도착지, 소요 시간)을 삽입
pq.add(new AbstractMap.SimpleEntry<>(v.getKey(), alt));
}
}
}
}
// 결과 변수가 노드의 수와 같다면 모든 노드의 소요 시간을 측정했고, 도달 가능하다는 의미
if (dist.size() == n)
// 이 중 가장 오래 걸리는 지점의 소요 시간 추출
return Collections.max(dist.values());
// 같지 않다면 일부 노드에는 도달할 수 없으므로 문제 조건에 따라 -1 리턴
return -1;
}
}