Sponsored
Sponsored
Performing Depth-First Search (DFS) is a common way to traverse a tree or graph. We'll start from node 0 and explore as far as possible along each branch before backtracking, avoiding restricted nodes and those already visited.
Time Complexity: O(n) because each node is visited once.
Space Complexity: O(n) for storing the adjacency list and visited nodes information.
1from collections import defaultdict
2
3def reachableNodes(n, edges, restricted):
4 adj_list = defaultdict(list)
5 restricted_set = set(restricted)
6 for a, b in edges:
7 adj_list[a].append(b)
8 adj_list[b].append(a)
9
10 def dfs(node, visited):
11 if node in visited or node in restricted_set:
12 return 0
13 visited.add(node)
14 count = 1
15 for neighbor in adj_list[node]:
16 count += dfs(neighbor, visited)
17 return count
18
19 return dfs(0, set())
The Python solution uses defaultdict for adjacency list storage, and a set to keep track of visited nodes. DFS traverses from node 0 while avoiding restricted nodes.
Breadth-First Search (BFS) can also be used to traverse the tree level-by-level. Starting from node 0, visit all neighbors at the current depth before moving on to nodes at the next depth level, while skipping restricted nodes.
Time Complexity: O(n) because each node is processed once using BFS.
Space Complexity: O(n) for adjacency list and other arrays.
1#include <vector>
#include <queue>
#include <unordered_set>
using namespace std;
int reachableNodes(int n, vector<vector<int>>& edges, vector<int>& restricted) {
unordered_set<int> restrictedSet(restricted.begin(), restricted.end());
vector<vector<int>> adjList(n);
for (auto& edge : edges) {
adjList[edge[0]].push_back(edge[1]);
adjList[edge[1]].push_back(edge[0]);
}
queue<int> q;
vector<bool> visited(n, false);
q.push(0);
visited[0] = true;
int count = 0;
while (!q.empty()) {
int node = q.front(); q.pop();
count++;
for (int neighbor : adjList[node]) {
if (!restrictedSet.count(neighbor) && !visited[neighbor]) {
visited[neighbor] = true;
q.push(neighbor);
}
}
}
return count;
}
In this C++ solution, BFS is implemented using a queue. Nodes are enqueued if they aren't restricted and haven't been visited, ensuring BFS traversal from node 0.