-
Notifications
You must be signed in to change notification settings - Fork 154
/
redundant-connection.js
78 lines (70 loc) · 2.06 KB
/
redundant-connection.js
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
76
77
78
/**
* Redundant Connection
*
* In this problem, a tree is an undirected graph that is connected and has no cycles.
*
* The given input is a graph that started as a tree with N nodes (with distinct values 1, 2, ..., N),
* with one additional edge added. The added edge has two different vertices chosen from 1 to N,
* and was not an edge that already existed.
*
* The resulting graph is given as a 2D-array of edges. Each element of edges is a pair [u, v] with u < v,
* that represents an undirected edge connecting nodes u and v.
*
* Return an edge that can be removed so that the resulting graph is a tree of N nodes. If there are multiple
* answers, return the answer that occurs last in the given 2D-array. The answer edge [u, v] should be in the
* same format, with u < v.
*
* Example 1:
* Input: [[1,2], [1,3], [2,3]]
* Output: [2,3]
*
* Explanation: The given undirected graph will be like this:
*
* 1
* / \
* 2 - 3
*
* Example 2:
* Input: [[1,2], [2,3], [3,4], [1,4], [1,5]]
* Output: [1,4]
*
* Explanation: The given undirected graph will be like this:
*
* 5 - 1 - 2
* | |
* 4 - 3
*
* Note:
* The size of the input 2D-array will be between 3 and 1000.
* Every integer represented in the 2D-array will be between 1 and N, where N is the size of the input array.
*
* Update (2017-09-26):
* We have overhauled the problem description + test cases and specified clearly the graph is an undirected graph.
* For the directed graph follow up please see Redundant Connection II). We apologize for any inconvenience caused.
*/
/**
* @param {number[][]} edges
* @return {number[]}
*/
const findRedundantConnection = edges => {
const nums = Array(2000).fill(-1);
const find = i => {
if (nums[i] === -1) {
return i;
}
return find(nums[i]);
};
for (let i = 0; i < edges.length; i++) {
const edge = edges[i];
// Find
const x = find(edge[0]);
const y = find(edge[1]);
if (x === y) {
return edge;
}
// Union
nums[x] = y;
}
return [];
};
export default findRedundantConnection;