本文主要是介绍05-5.5.3 并查集的进一步优化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
👋 Hi, I’m @Beast Cheng
👀 I’m interested in photography, hiking, landscape…
🌱 I’m currently learning python, javascript, kotlin…
📫 How to reach me --> 458290771@qq.com
喜欢《数据结构》部分笔记的小伙伴可以订阅专栏,今后还会不断更新。🧑💻
感兴趣的小伙伴可以点一下订阅、收藏、关注!🚀
谢谢大家!🙏
拓展:Find 操作的优化(压缩路径)
压缩路径——Find
操作,先找到根结点,再将查找路径上所有的结点都挂到根结点下
int Find(int S[], int x){int root = x;while(S[root] >= 0) root = S[root]; // 循环找到根while(x != root){ // 父结点int t = S[x]; // t 指向 x 的父结点S[x] = root; // x 直接挂到根结点下x = t;}return root; // 返回根结点编号
}
每次 Find
操作,先找根,再 “压缩路径” ,可使树的高度不超过 O ( α ( n ) ) O(\alpha(n)) O(α(n)) 。 α ( n ) \alpha(n) α(n) 是一个增长很缓慢的函数,对于常见的 n 值,通常 α ( n ) ≤ 4 \alpha(n)\leq4 α(n)≤4 ,因此优化后并查集的 Find、Union
操作时间开销都很低
这篇关于05-5.5.3 并查集的进一步优化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!