Detect Cycle
Cycle in Undirected Graph
1. Implementation
public static boolean hasCycle(int[][] edges, int n) {
List<List<Integer>> adjList = new ArrayList<>();
for (int i = 0; i < n; i++) {
adjList.add(new ArrayList<>());
}
for (int[] edge : edges) {
adjList.get(edge[0]).add(edge[1]);
adjList.get(edge[1]).add(edge[0]);
}
boolean[] visited = new boolean[n];
for (int i = 0; i < n; i++) {
if (!visited[i]) {
if (detectCycle(i, -1, visited, adjList)) {
return true;
}
}
}
return false;
}
public static boolean detectCycle(int curVertex, int parent, boolean[] visited, List<List<Integer>> adjList) {
visited[curVertex] = true;
for (int nextVertex : adjList.get(curVertex)) {
if (!visited[nextVertex]) {
if (detectCycle(nextVertex, curVertex, visited, adjList)) {
return true;
}
}
// If an adjacent is visited and not parent of current vertex, then there is a cycle.
else if (nextVertex != parent) {
return true;
}
}
return false;
}2. Time Complexity
Time: O(V + E)
Space: O(V + E)
Cycle in Directed Graph
1. Detect Cycle with Coloring
2. Time Complexity
Time: O(V + E)
Space: O(V + E)
Last updated
Was this helpful?