3607. Power Grid Maintenance
Description
You are given an integer c representing c power stations, each with a unique identifier id from 1 to c (1‑based indexing).
These stations are interconnected via n bidirectional cables, represented by a 2D array connections, where each element connections[i] = [ui, vi] indicates a connection between station ui and station vi. Stations that are directly or indirectly connected form a power grid.
Initially, all stations are online (operational).
You are also given a 2D array queries, where each query is one of the following two types:
-
[1, x]: A maintenance check is requested for stationx. If stationxis online, it resolves the check by itself. If stationxis offline, the check is resolved by the operational station with the smallestidin the same power grid asx. If no operational station exists in that grid, return -1. -
[2, x]: Stationxgoes offline (i.e., it becomes non-operational).
Return an array of integers representing the results of each query of type [1, x] in the order they appear.
Note: The power grid preserves its structure; an offline (non‑operational) node remains part of its grid and taking it offline does not alter connectivity.
Example 1:
Input: c = 5, connections = [[1,2],[2,3],[3,4],[4,5]], queries = [[1,3],[2,1],[1,1],[2,2],[1,2]]
Output: [3,2,3]
Explanation:
- Initially, all stations
{1, 2, 3, 4, 5}are online and form a single power grid. - Query
[1,3]: Station 3 is online, so the maintenance check is resolved by station 3. - Query
[2,1]: Station 1 goes offline. The remaining online stations are{2, 3, 4, 5}. - Query
[1,1]: Station 1 is offline, so the check is resolved by the operational station with the smallestidamong{2, 3, 4, 5}, which is station 2. - Query
[2,2]: Station 2 goes offline. The remaining online stations are{3, 4, 5}. - Query
[1,2]: Station 2 is offline, so the check is resolved by the operational station with the smallestidamong{3, 4, 5}, which is station 3.
Example 2:
Input: c = 3, connections = [], queries = [[1,1],[2,1],[1,1]]
Output: [1,-1]
Explanation:
- There are no connections, so each station is its own isolated grid.
- Query
[1,1]: Station 1 is online in its isolated grid, so the maintenance check is resolved by station 1. - Query
[2,1]: Station 1 goes offline. - Query
[1,1]: Station 1 is offline and there are no other stations in its grid, so the result is -1.
Constraints:
1 <= c <= 1050 <= n == connections.length <= min(105, c * (c - 1) / 2)connections[i].length == 21 <= ui, vi <= cui != vi1 <= queries.length <= 2 * 105queries[i].length == 2queries[i][0]is either 1 or 2.1 <= queries[i][1] <= c
Solutions
Solution 1: Union-Find + Sorted Set
We can use Union-Find to maintain the connection relationships between power stations, thereby determining which grid each station belongs to. For each grid, we use a sorted set (such as SortedList in Python, TreeSet in Java, or std::set in C++) to store all online station IDs in that grid, allowing efficient querying and deletion of stations.
The specific steps are as follows:
- Initialize the Union-Find structure and process all connection relationships, merging connected stations into the same set.
- Create a sorted set for each grid, initially adding all station IDs to their corresponding grid's set.
- Iterate through the query list:
- For query \([1, x]\), first find the root node of the grid that station \(x\) belongs to, then check that grid's sorted set:
- If station \(x\) is online (exists in the set), return \(x\).
- Otherwise, return the station with the smallest ID in the set (if the set is non-empty), otherwise return -1.
- For query \([2, x]\), find the root node of the grid that station \(x\) belongs to, and remove station \(x\) from that grid's sorted set, indicating that the station is offline.
- For query \([1, x]\), first find the root node of the grid that station \(x\) belongs to, then check that grid's sorted set:
- Finally, return all query results of type \([1, x]\).
The time complexity is \(O((c + n + q) \log c)\) and the space complexity is \(O(c)\), where \(c\) is the number of stations, and \(n\) and \(q\) are the number of connections and queries, respectively.
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 | |
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 | |
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 | |
1 | |
