forked from fishercoder1534/Leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path_2039.java
75 lines (72 loc) · 2.89 KB
/
_2039.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package com.fishercoder.solutions;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.Map;
import java.util.Queue;
import java.util.Set;
public class _2039 {
public static class Solution1 {
/**
* My completely original solution, again, using a pen and paper to visualize my thought process helps out greatly!
*/
public int networkBecomesIdle(int[][] edges, int[] patience) {
int n = patience.length;
int[] distances = findShortestPathToMasterServer(edges, n);
int seconds = 0;
for (int i = 1; i < n; i++) {
int roundTripTime = distances[i] * 2;
int numberOfMessages = roundTripTime / patience[i];
int lastMessageArriveTime = roundTripTime;
if (roundTripTime > patience[i]) {
lastMessageArriveTime += patience[i] * (roundTripTime % patience[i] == 0 ? (numberOfMessages - 1) : numberOfMessages);
}
seconds = Math.max(seconds, lastMessageArriveTime);
}
return seconds + 1;
}
private int[] findShortestPathToMasterServer(int[][] edges, int n) {
int[] distances = new int[n];
Arrays.fill(distances, n);
Queue<Integer> queue = new LinkedList<>();
Map<Integer, Set<Integer>> neighborsMap = new HashMap<>();
for (int[] edge : edges) {
if (edge[0] == 0) {
queue.offer(edge[1]);
}
if (edge[1] == 0) {
queue.offer(edge[0]);
}
Set<Integer> set1 = neighborsMap.getOrDefault(edge[0], new HashSet<>());
set1.add(edge[1]);
neighborsMap.put(edge[0], set1);
Set<Integer> set2 = neighborsMap.getOrDefault(edge[1], new HashSet<>());
set2.add(edge[0]);
neighborsMap.put(edge[1], set2);
}
int distance = 1;
boolean[] visited = new boolean[n];
visited[0] = true;
while (!queue.isEmpty()) {
int size = queue.size();
for (int i = 0; i < size; i++) {
Integer curr = queue.poll();
if (visited[curr]) {
continue;
}
visited[curr] = true;
distances[curr] = Math.min(distance, distances[curr]);
Set<Integer> neighbors = neighborsMap.getOrDefault(curr, new HashSet<>());
for (int neighbor : neighbors) {
if (!visited[neighbor]) {
queue.offer(neighbor);
}
}
}
distance++;
}
return distances;
}
}
}