当前位置: 首页 > ai >正文

数据结构|并查集

Hello !朋友们,这是我在学习过程中梳理的笔记,以作以后复习回顾,有时略有潦草,一些话是我用自己的话描述的,可能不够准确,还是感谢大家的阅读!

目录

一、并查集Quickfind

二、两种算法

1)QuickFind[快查找]

思想:

代码框架:

2)QuickUnion[快合并]

思想:

基于size的算法优化:元素少的树,嫁接到元素多的树

基于rank的算法改进:矮的树,嫁接到高的树

路径压缩:所有元素都指向根结点

代码实现步骤:

代码框架:


一、并查集Quickfind

并查集是一种用于处理不相交集合合并查询问题的数据结构。以下是其相关概念:

  • 基本操作
    • 合并(Union):将两个不相交的集合合并为一个集合。
    • 查找(Find):确定一个元素属于哪个集合,通常返回该集合的代表元素。
  • 实现原理
    • 并查集通常使用树结构来实现,每个集合对应一棵树。树中的节点代表集合中的元素,根节点作为集合的代表元素。
    • 用一个数组来存储每个元素的父节点信息,通过不断查找父节点,最终找到根节点,从而确定元素所属的集合。
  • 路径压缩优化:在查找操作中,为了提高效率,可以采用路径压缩的优化方法。即在查找元素的根节点时,将路径上的所有节点直接连接到根节点,这样下次查找时就可以更快地找到根节点。
  • 应用场景
    • 连通性问题:判断图中两个节点是否连通,例如在网络拓扑中,判断两个设备是否通过网络连接。
    • 最小生成树:在构建最小生成树的过程中,用于判断两个顶点是否在同一个连通分量中,避免形成环。
    • 集合划分:将一组元素划分为不同的不相交集合,例如将一群人按照不同的兴趣爱好划分成不同的小组。

二、两种算法

并查集有两种算法,一种是快查找(QuickFind),另一种是快合并(QuickUnion),两种都要实现查找和和合并,只不过使用的不同的方法。

1)QuickFind[快查找]

查找效率:O(1)    合并效率:O(N)

思想:

查找:查找两个数是否在一组,借用索引,看两个数的ID是否相等

合并:合并两个组,将第二个组里所有的值的组号改为第一个组的组号

代码框架:

2)QuickUnion[快合并]

查找效率:O(logN)    合并效率:O(logN)

思想:

查找:查看两个数是否在一组,看两个数根ID是不是同一个,相等则是同一个,不等则不是同一组。

合并:不是合并a,b,而是a的根节点和b的根结点进行合并合并a合并到b,b合并到a都不一定是最好的,所以需要优化算法】(掌握一个就可以)

  • 基于size的算法优化元素少的树,嫁接到元素多的树
  • (目前我是这样理解的,不知道有没有错)
  • 基于rank的算法改进矮的树,嫁接到高的树
  • 路径压缩所有元素都指向根结点
  • 使路径上的所有结点都指向根结点,从而降低树的高度

代码实现步骤:

1、申请空间:根据需要给每个部分都申请出空间

2、初始化:给每个部分赋上初始的值

找索引

找根ID

3、查找:判断两个元素是否在一个集合,返回0,1)判断两个元素的根结点是否相同,则需要找到该借点,然后沿着起父节点找到根结点,最后比较根ID的值。

4、合并:

5、释放空间:

代码框架:

 

http://www.xdnf.cn/news/2836.html

相关文章:

  • 将infinigen功能集成到UE5--在ue里面写插件(python和c++)
  • 从数据到决策:安科瑞EIoT如何让每一度电“清晰可见”?
  • IF:22.7 InfoMat:一种用于智能假肢的机器学习辅助多功能触觉传感器
  • 考研408-计算机组成原理冲刺考点(4-5章)
  • 方案精讲:71页央国企信创化与数字化转型规划实施【附全文阅读】
  • Logback 日志框架详解
  • 【自然语言处理与大模型】LangChain大模型应用框架入门②
  • Selenium 与 Playwright:浏览器自动化工具的深度对比
  • ComfyUI 学习笔记,案例1:2_pass_txt2img
  • 案例速成GO+Socket,个人笔记
  • WEBSTORM前端 —— 第2章:CSS —— 第4节:盒子模型
  • 【AI News | 20250429】每日AI进展
  • 破茧成蝶:一家传统制造企业的年轻化转型之路
  • VS Code + Linux 远程开发 go
  • 2025年具身智能科技研报
  • C++函数模板基础
  • 【专题五】位运算(1):常见位运算操作总结
  • DeepSeek: 探索未来的深度学习搜索引擎
  • 第十六届蓝桥杯 2025 C/C++组 脉冲强度之和
  • Origin绘图操作:点线图符号显示不全解决方法
  • 接入层架构演变
  • Nginx 核心功能与 LNMP 架构部署
  • C#解析USB - HID手柄上摇杆按键数据
  • Ubuntu 20.04 安装 ROS 2 Foxy Fitzroy
  • xilinx的XCI文件设定输出目录
  • MIT XV6 - 1.1 Lab: Xv6 and Unix utilities - sleep 是怎样练成的?
  • [AI]browser-use + web-ui 大模型实现自动操作浏览器
  • 元宇宙2.0:当区块链成为数字世界的宪法
  • 【C++初阶】--- 模板进阶
  • (三十二)Android开发中AppCompatActivity和Activity之间的详细区别