Quick Union: Exercise
- Explain the runtime improvements gained by using the heuristics for union-find operations.
- Define the iterated logarithm (log-star) function.
- Identify the amortized runtime of union-find operations.
Suppose you have singleton sets with the values $0$ through $6$. Then, we apply the following operations.
union(0,5)
union(1,4)
union(2,3)
union(3,6)
union(4,6)
union(0,4)
Exercise Using both tree and array forms, show the result of each of the operations listed above, applying union-by-size and path compression heuristics.
Solution
Here is the start:
data:image/s3,"s3://crabby-images/cc13e/cc13ef00931db690a5e607a88d64f0da201fd0a1" alt=""
After union(0,5)
:
data:image/s3,"s3://crabby-images/19739/1973975688eb17bd507eaa1c00ffaf83d9bbe634" alt=""
After union(1,4)
:
data:image/s3,"s3://crabby-images/4eeab/4eeabd722c3b8fed7153ee962645b23ff36d28b8" alt=""
After union(2,3)
:
data:image/s3,"s3://crabby-images/4b69e/4b69e1e630adc8861fa21dbe33ecd090d11a5976" alt=""
After union(3,6)
: notice the size of the component containing $6$ is smaller than the size of the component containing $3$. Therefore, the component containing $6$ is added to the root of the component containing $3$.
data:image/s3,"s3://crabby-images/f9346/f93461aeea27433a241d68be887fb7d0cf250a4c" alt=""
After union(4,6)
: notice the size of the component containing $4$ is smaller than the size of the component containing $6$. Therefore, the component containing $4$ is added to the root of the component containing $6$.
data:image/s3,"s3://crabby-images/c3c10/c3c1030ebf654ae049329f9e312af66cbb7d4e52" alt=""
After union(0,4)
: notice as we find the root of the component containing $4$, we apply path compression.
data:image/s3,"s3://crabby-images/01855/01855aa8eb086ba60e4b642ec5e736baa924ae7d" alt=""
Then, as the size of the component containing $0$ is smaller than the size of the component containing $4$, the component containing $0$ is added to the root of the component containing $4$.
data:image/s3,"s3://crabby-images/c108b/c108bb3de6c8a1cd2ad5971468a0abc909b033e9" alt=""