首页 > 后端开发 > C++ > 正文

c++怎么实现一个并查集(Disjoint Set Union)_C++实现Union-Find并查集算法详解

下次还敢
发布: 2025-10-31 09:44:02
原创
470人浏览过
并查集通过Find和Union操作管理分组,支持路径压缩与按秩合并优化,用于高效处理连通性问题。

c++怎么实现一个并查集(disjoint set union)_c++实现union-find并查集算法详解

并查集(Disjoint Set Union,简称 DSU 或 Union-Find)是一种高效管理元素分组的数据结构,支持快速合并集合与查询元素所属集合。它常用于处理无向图的连通性问题,比如判断两个节点是否连通、求连通分量个数等。

基本结构与操作

并查集主要包含两个核心操作:

  • Find(x):查找元素 x 所在集合的代表(根节点)
  • Union(x, y):将元素 x 和 y 所在集合合并

为了提升效率,通常结合路径压缩按秩合并两种优化策略。

基础实现代码

// 并查集类实现 class UnionFind { private: vector parent; // 父节点数组 vector rank; // 秩(树的高度上界) public: // 构造函数,初始化每个元素为独立集合 UnionFind(int n) { parent.resize(n); rank.resize(n, 0); for (int i = 0; i rank[rootY]) { parent[rootY] = rootX; } else { parent[rootY] = rootX; rank[rootX]++; // 高度相等时,合并后高度+1 } } // 判断两个元素是否在同一集合 bool connected(int x, int y) { return find(x) == find(y); } };

使用示例

假设我们有 5 个元素(0~4),进行一些合并与查询操作:

立即学习C++免费学习笔记(深入)”;

集简云
集简云

软件集成平台,快速建立企业自动化与智能化

集简云22
查看详情 集简云
int main() { UnionFind uf(5); uf.unite(0, 1); uf.unite(1, 2); uf.unite(3, 4); cout

优化说明

上述实现中两个关键优化显著提升了性能:

  • 路径压缩:在 find 过程中,把沿途所有节点直接连到根节点,降低后续查询成本
  • 按秩合并:合并时让深度小的树挂到深度大的树上,防止树退化为链表

经过这两种优化后,并查集的每次操作平均时间复杂度接近 O(α(n)),其中 α 是阿克曼函数的反函数,增长极慢,可视为常数。

基本上就这些。这个结构简单但非常实用,尤其适合处理动态连通性问题。

以上就是c++++怎么实现一个并查集(Disjoint Set Union)_C++实现Union-Find并查集算法详解的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号