Back to Practice Dashboard
DSA SectionEasy

Union Find

Learn how to solve the 'Union Find' problem. This detailed resource details brute force and optimized approaches.

Problem Statement

Easy

Write a function detect_cycle_union_find(V, edges) that detects if there is a cycle in an undirected graph of V vertices and a list of edges edges represented as pairs (u, v) using the Union-Find data structure. Return True if a cycle exists, else False.

Constraints
  • 1 <= V <= 1000
  • 0 <= len(edges) <= 2000

Examples

Example 1
Input
V = 3, edges = [(0, 1), (1, 2), (2, 0)]
Output
True
Explanation

Edge (2, 0) connects vertices 2 and 0 which are already in the same subset, detecting a cycle.

Example 2
Input
V = 3, edges = [(0, 1), (1, 2)]
Output
False
Explanation

No subset connections merge vertices already in the same subset.

Need a Hint?
Represent graph node connections as an adjacency list/matrix, then use standard BFS or DFS graph traversal.
Edge Cases to Watch
  • Empty list or null input variables
  • Single item lists/arrays
  • Extremely large input bounds causing integer or stack overflow

Ready to Solve?

Open the problem in PyRun's browser-based Python editor. Your code runs fully offline — no server required.

Open in Editor