采纳答案成功!
向帮助你的同学说点啥吧!感谢那些助人为乐的人
我也总结了一下,其实基于rank和size的优化是写在union方法里的,而路径压缩是写在find方法里的,union方法内使用了find方法,所以优化了find其实也是优化union方法。
我实现了一个只使用路径压缩而不使用基于rank优化的方法,发现效果比使用了rank优化差一点点(这也说明了路径压缩的威力),这时为什么呢?
主要是rank的优化和路径压缩的优化,本质都是在降低并查集树的高度,所以二者的作用是有重叠的。同时,路径压缩能在更普遍的情况下极大的降低树的高度,所以rank的优化作用在路径压缩下就不明显了。毕竟,即使不考虑rank,就算做出一颗很高的树,在路径压缩的时候,这个很高的“数枝”也会一下子被“压缩”。
确实有很多人实现并查集(尤其是在比赛中),是不实现rank优化的,对结果影响很小:)但在极端测试数据下还是会有差别的,毕竟“压缩”一个“很高的数枝”比压缩一个“相对较矮的数值”要耗时一些。
非常感谢!
登录后可查看更多问答,登录/注册
课程专为:短时间内应对面试、升职测评等艰巨任务打造
8.8k 21
5.8k 3
5.0k 5
1.4k 18