Quick Union: Exercise
Suppose you have singleton sets with the values $0$ through $6$. 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/93aba/93aba1515d5ff7894a7df370f1b913227015d28a" alt=""
After union(0,5)
:
data:image/s3,"s3://crabby-images/9dde5/9dde53d241897434aa758cd906ef24ede6faf49a" alt=""
After union(1,4)
:
data:image/s3,"s3://crabby-images/cb9a9/cb9a9592b1d1b756f42762e5a9a7bbfdaacf02ee" alt=""
After union(2,3)
:
data:image/s3,"s3://crabby-images/b3339/b3339bf972656424897aea2a51ec8d9f2c2536f7" 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/40c23/40c2309a73d98300ed013cefc80500df509e9493" 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/e9e3b/e9e3b0bfc3f86580092e6123accdfce4169a8d1a" 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/35cf1/35cf1581d8ac734e711a25fd5579f2620e7d1013" 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/51a66/51a66922b080b515c7d0a6395944c9630195d458" alt=""