You are given a 2D integer array points, where points[i] = [xi, yi] represents the coordinates of the ith point. All coordinates in points are distinct.
If a point is activated, then all points that have the same x-coordinate or y-coordinate become activated as well.
Activation continues until no additional points can be activated.
You may add one additional point at any integer coordinate (x, y) not already present in points. Activation begins by activating this newly added point.
Return an integer denoting the maximum number of points that can be activated, including the newly added point.
Β
Example 1:
Input:points = [[1,1],[1,2],[2,2]]
Output:4
Explanation:
Adding and activating a point such as (1, 3) causes activations:
(1, 3) shares x = 1 with (1, 1) and (1, 2) -> (1, 1) and (1, 2) become activated.
(1, 2) shares y = 2 with (2, 2) -> (2, 2) becomes activated.
Thus, the activated points are (1, 3), (1, 1), (1, 2), (2, 2), so 4 points in total. We can show this is the maximum activated.
Example 2:
Input:points = [[2,2],[1,1],[3,3]]
Output:3
Explanation:
Adding and activating a point such as (1, 2) causes activations:
(1, 2) shares x = 1 with (1, 1) -> (1, 1) becomes activated.
(1, 2) shares y = 2 with (2, 2) -> (2, 2) becomes activated.
Thus, the activated points are (1, 2), (1, 1), (2, 2), so 3 points in total. We can show this is the maximum activated.
Example 3:
Input:points = [[2,3],[2,2],[1,1],[4,5]]
Output:4
Explanation:
Adding and activating a point such as (2, 1) causes activations:
(2, 1) shares x = 2 with (2, 3) and (2, 2) -> (2, 3) and (2, 2) become activated.
(2, 1) shares y = 1 with (1, 1) -> (1, 1) becomes activated.
Thus, the activated points are (2, 1), (2, 3), (2, 2), (1, 1), so 4 points in total.
Β
Constraints:
1 <= points.length <= 105
points[i] = [xi, yi]
-109 <= xi, yi <= 109
points contains all distinct coordinates.
Solutions
Solution 1: Union-Find
We can use a Union-Find data structure to solve this problem.
First, we map the \(x\) coordinates and \(y\) coordinates of all points into the same Union-Find structure. Specifically, we add a sufficiently large constant \(m\) (e.g., \(3 \times 10^9\)) to each \(y\) coordinate to ensure that the \(x\) and \(y\) coordinates do not conflict.
Next, we iterate over all points and union those that share the same \(x\) coordinate or the same \(y\) coordinate. This way, points with the same \(x\) or \(y\) coordinate will be grouped into the same set.
Finally, we count the number of points in each set and find the sizes of the two largest sets. Since we can add one new point to connect these two sets, the final answer is the sum of the sizes of the two largest sets plus \(1\).
The time complexity is \(O(n \alpha(n))\), where \(n\) is the number of points and \(\alpha\) is the inverse Ackermann function. The space complexity is \(O(n)\).