Improvement 2: Path Compression
- Trace the Quick Union implementation with path-compression heuristic.
- Explain the runtime improvements gained by using the heuristic for union-find operations.
After computing the root of $p$, set the ID of each examined node to point to that root.
For example, consider the following tree:
data:image/s3,"s3://crabby-images/0d8e4/0d8e429939a09fa8762186c19737063482063c07" alt=""
Assume we perform find(J)
operation. On our way to find the root, we would pass through $I$, $F$, $B$ until we get to $A$, the root.
We could set all these vertices to directly point to the root, so the tree becomes shallower:
data:image/s3,"s3://crabby-images/322b4/322b48956f16278374f2971c95877289382a2fda" alt=""
The heuristic described above is known as path compression.