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

数据结构详细笔记——并查集

文章目录

  • 逻辑结构
  • 存储结构
  • 并、查代码实现
    • Union 操作的优化
    • Find 操作的优化(压缩路径)


逻辑结构

集合:将各个元素划分为若干个互不相交的子集的集合
森林是m(m>=0)棵互不相交的树的集合

存储结构

#define SIZE 13
int UFSets[SIZE];    // 集合元素数组// 初始化并查集
void Initial(int S[]){for(int i=0;i<SIZE;i++)S[i] = -1;
}

并、查代码实现

// Find 查操作,找x所属集合(返回x所属的根结点) 时间复杂度O(n)
int Find(int S[],int x){while(S[x]>0)  // 循环寻找x的根x=S[x];return x;      // 根的S【】小于0
}// Union 并操作,将两个集合合并为一个  时间复杂度O(n)
void Union(int S[],int Root1,int Root2){// 要求Root1与Root2是不同的集合if(Root1==Root2) return// 将根Root2连接到另一根Root1下面S[Root2]=Root1;

Union 操作的优化

优化思路:在每次Union操作构建树的时候,尽可能让树不长高
①用根结点的绝对值表示树的结点的总数
②Union操作,让小树合并到大树

// Union 并操作,小树合并到大树 时间复杂度O(log2(n))
void Union(int S[],int Root1,int Root2){if(Root1==Root2) return;if(S[Root2]>S[Root1]){  // Root2 结点数更少S[Root1] += S[Root2];  // 累加结点总数S[Root2] = Root1;  // 小树合并大树} else{S[Root2] += S[Root1];S[Root1] = Root2;}
}

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;  // 返回根结点编号
}
http://www.lryc.cn/news/214039.html

相关文章:

  • transformers-Generation with LLMs
  • maven之父子工程版本控制案例实战,及拓展groupId和artifactId的含义
  • 100量子比特启动实用化算力标准!玻色量子重磅发布相干光量子计算机
  • JAVA基础(JAVA SE)学习笔记(十)多线程
  • ChatGPT参数只有200亿?扩散代码模型,意外泄露
  • VR虚拟仿真教学在建筑学课堂中的应用
  • 竞赛 深度学习实现行人重识别 - python opencv yolo Reid
  • 当代都市的时尚先锋:气膜建筑的魅力
  • 品牌加盟商做信息展示预约小程序的效果如何
  • delphi 11.3 FastReport 多设备跨平台 打印之解决方法
  • 配置vue 环境
  • Visio文件编辑查看工具Visio Viewer for Mac
  • 现在软文发布平台都有哪些?如何在正规媒体发稿?
  • 【卷积神经网络】YOLO 算法原理
  • 云计算与ai人工智能对高防cdn的发展
  • Web3时代:探索DAO的未来之路
  • odbcinst文件
  • (CQUPT 的某数据结构homework)
  • Android页面周期、页面跳转
  • 腾讯云轻量应用镜像、系统镜像、Docker基础镜像、自定义镜像和共享镜像介绍
  • YOLOv8芒果独家首发 | 改进新主干:改进版目标检测新范式骨干PPHGNetv2,百度出品,提升YOLOv8检测能力
  • 工作测试点
  • 智慧医院—互联网医院系统带你体验数字化时代
  • eclipse Occurrence
  • 浏览器自动化脚本 Selenium WebDriver(Java)常用 API 汇总
  • 学习笔记|两独立样本秩和检验|曼-惠特尼 U数据分布图|规范表达|《小白爱上SPSS》课程:SPSS第十二讲 | 两独立样本秩和检验如何做?
  • 【Python微信机器人】第三篇:使用ctypes调用进程函数和读取内存结构体
  • easyExcel按模板填充数据,处理模板列表合并问题等,并导出为html,pdf,png等格式文件demo
  • 怎么开发小程序?微信小程序开发方式
  • 测试从外包到自研再到大厂,这5年鬼知道我是怎么过来的