27. Detect Cycle using DSU

The problem can be found at the following link: Question Link

My Approach

I used the Disjoint Set Union (DSU) data structure to detect cycles in an undirected graph. The steps are outlined as follows:

  • Step 1: Initialize DSU data structure.

  • Step 2: Iterate through each vertex in the graph.

  • Step 3: For each vertex, iterate through its adjacent vertices.

  • Step 4: If the current vertex and its adjacent vertex belong to the same set, there is a cycle. Merge the sets and return true.

  • Step 5: If the sets are different, perform the union operation.

  • Step 6: Continue the process for all vertices.

  • Step 7: If a cycle is found during the process, return true. Otherwise, return false.

For a clearer explanation of the solution, please check this solution.

Time and Auxiliary Space Complexity

  • Time Complexity: O(V + E), where V is the number of vertices and E is the number of edges.

  • Auxiliary Space Complexity: O(V) for DSU data structure.

Code (C++)

Contribution and Support

For discussions, questions, or doubts related to this solution, please visit our discussion section. We welcome your input and aim to foster a collaborative learning environment.

If you find this solution helpful, consider supporting us by giving a ⭐ star to the getlost01/gfg-potd repository.

Last updated

Was this helpful?