Skip to content

Commit b36f85f

Browse files
Sync LeetCode submission Runtime - 80 ms (69.66%), Memory - 44.4 MB (68.82%)
1 parent 093a37e commit b36f85f

2 files changed

Lines changed: 70 additions & 0 deletions

File tree

Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
<p>You are given a network of <code>n</code> nodes, labeled from <code>1</code> to <code>n</code>. You are also given <code>times</code>, a list of travel times as directed edges <code>times[i] = (u<sub>i</sub>, v<sub>i</sub>, w<sub>i</sub>)</code>, where <code>u<sub>i</sub></code> is the source node, <code>v<sub>i</sub></code> is the target node, and <code>w<sub>i</sub></code> is the time it takes for a signal to travel from source to target.</p>
2+
3+
<p>We will send a signal from a given node <code>k</code>. Return <em>the <strong>minimum</strong> time it takes for all the</em> <code>n</code> <em>nodes to receive the signal</em>. If it is impossible for all the <code>n</code> nodes to receive the signal, return <code>-1</code>.</p>
4+
5+
<p>&nbsp;</p>
6+
<p><strong class="example">Example 1:</strong></p>
7+
<img alt="" src="https://assets.leetcode.com/uploads/2019/05/23/931_example_1.png" style="width: 217px; height: 239px;" />
8+
<pre>
9+
<strong>Input:</strong> times = [[2,1,1],[2,3,1],[3,4,1]], n = 4, k = 2
10+
<strong>Output:</strong> 2
11+
</pre>
12+
13+
<p><strong class="example">Example 2:</strong></p>
14+
15+
<pre>
16+
<strong>Input:</strong> times = [[1,2,1]], n = 2, k = 1
17+
<strong>Output:</strong> 1
18+
</pre>
19+
20+
<p><strong class="example">Example 3:</strong></p>
21+
22+
<pre>
23+
<strong>Input:</strong> times = [[1,2,1]], n = 2, k = 2
24+
<strong>Output:</strong> -1
25+
</pre>
26+
27+
<p>&nbsp;</p>
28+
<p><strong>Constraints:</strong></p>
29+
30+
<ul>
31+
<li><code>1 &lt;= k &lt;= n &lt;= 100</code></li>
32+
<li><code>1 &lt;= times.length &lt;= 6000</code></li>
33+
<li><code>times[i].length == 3</code></li>
34+
<li><code>1 &lt;= u<sub>i</sub>, v<sub>i</sub> &lt;= n</code></li>
35+
<li><code>u<sub>i</sub> != v<sub>i</sub></code></li>
36+
<li><code>0 &lt;= w<sub>i</sub> &lt;= 100</code></li>
37+
<li>All the pairs <code>(u<sub>i</sub>, v<sub>i</sub>)</code> are <strong>unique</strong>. (i.e., no multiple edges.)</li>
38+
</ul>
Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
class Solution {
2+
public:
3+
int networkDelayTime(vector<vector<int>>& times, int n, int k) {
4+
vector<vector<pair<int, int>>> graph(n);
5+
for (auto& t : times) graph[t[0]-1].push_back({t[1]-1, t[2]});
6+
7+
priority_queue<pair<int, int>, vector<pair<int, int>>, greater<pair<int, int>>> pq;
8+
vector<int> costs(n, 1e9);
9+
costs[k-1] = 0;
10+
pq.push({0, k-1});
11+
while (!pq.empty()) {
12+
auto [cost, node] = pq.top();
13+
pq.pop();
14+
15+
if (cost > costs[node]) continue;
16+
17+
for (auto& neigh : graph[node]) {
18+
int newNode = neigh.first;
19+
int newCost = cost + neigh.second;
20+
21+
if (newCost < costs[newNode]) {
22+
costs[newNode] = newCost;
23+
pq.push({newCost, newNode});
24+
}
25+
}
26+
}
27+
28+
int ans = *max_element(costs.begin(), costs.end());
29+
30+
return (ans < 1e9 ? ans : -1);
31+
}
32+
};

0 commit comments

Comments
 (0)