Quick Union: Exercise
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/01aaf/01aafed3efb40063e0189c6adc794c4d6b8beda2" alt=""
After union(0,5)
:
data:image/s3,"s3://crabby-images/c1680/c168004d9c67f88df95da19a3404021fc5c2a743" alt=""
After union(1,4)
:
data:image/s3,"s3://crabby-images/a3a11/a3a1182f49fc512f732d403ca411d4217295ec90" alt=""
After union(2,3)
:
data:image/s3,"s3://crabby-images/1b0cd/1b0cd44a9d4724b3c2b6cd8d8eeea4a943bef80e" 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/db732/db732f546eadd714ca23a3fdb7131d32868feb05" 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/cd7a0/cd7a0e523a9f647fcfd96479fe06cae76728c176" 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/1e4da/1e4da4a2b80e2abe39f1f6f12c4bde40aded1bc5" 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/4a6ed/4a6ed83fb208b435062cdfaf4a07c7d112203d43" alt=""