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

并查集基础

一、概念及其介绍

并查集是一种树型的数据结构,用于处理一些不相交集合的合并及查询问题。

并查集的思想是用一个数组表示了整片森林(parent),树的根节点唯一标识了一个集合,我们只要找到了某个元素的的树根,就能确定它在哪个集合里。

二、适用说明

并查集用在一些有 N 个元素的集合应用问题中,我们通常是在开始时让每个元素构成一个单元素的集合,然后按一定顺序将属于同一组的元素所在的集合合并,其间要反复查找一个元素在哪个集合中。这个过程看似并不复杂,但数据量极大,若用其他的数据结构来描述的话,往往在空间上过大,计算机无法承受,也无法在短时间内计算出结果,所以只能用并查集来处理。

三、并查集的基本数据表示

 如上图 0-4 下面都是 05-9 下面都是 1,表示 0、1、2、3、4 这五个元素是相连接的,5、6、7、8、9 这五个元素是相连的。

 

再如上图 0、2、4、6、8 下面都是 0 这个集合,表示 0、2、4、6、8 这五个元素是相连接的,1、3、5、7、9 下面都是 1 这个集合,表示 0,1、3、5、7、9 这五个元素是相连的。

构造一个类 UnionFind,初始化, 每一个id[i]指向自己, 没有合并的元素:

...
public UnionFind1(int n) {count = n;id = new int[n];// 初始化, 每一个id[i]指向自己, 没有合并的元素for (int i = 0; i < n; i++)id[i] = i;}
...

Java 实例代码

UnionFind.java 文件代码:

package runoob.union;public class UnionFind{private int[] id;// 数据个数private int count;public UnionFind1(int n) {count = n;id = new int[n];for (int i = 0; i < n; i++)id[i] = i;}}  
http://www.lryc.cn/news/102059.html

相关文章:

  • C# 循环等知识点
  • 1.1.2 SpringCloud 版本问题
  • Android AIDL 使用
  • MongoDB——命令详解
  • 机器学习深度学习——多层感知机的简洁实现
  • 笙默考试管理系统-MyExamTest(21)
  • Redis高可用之主从复制、哨兵、cluster集群
  • 【需求响应DR】一种新的需求响应机制DR-VCG研究(Python代码实现)
  • 【Django学习】(十六)session_token认证过程与区别_响应定制
  • ai创作系统CHATGPT支持GPT4.0+支持ai绘画(MJ)+ai绘画(SD)集合几百种AI智能工具
  • linux安装mysql
  • mysql主从复制原理及应用
  • 《Kubernetes故障篇:unable to retrieve OCI runtime error》
  • el-upload上传图片和视频,支持预览和删除
  • clickhouse MPPDB数据库 运维实用SQL总结III
  • ARM和MIPS的区别
  • TypeScript -- 类
  • 【LeetCode】124.二叉树中的最大路径和
  • Linux命令总结
  • SpringBoot临时属性设置
  • 【Python小知识】如何解决代理IP在多线程环境下的并发问题?
  • redis常见面试汇总
  • 子数组的解释与专题
  • PHP: 开发入门macOS系统下的安装和配置
  • 在CentOS下安装docker
  • [JavaWeb]SQL介绍-DQL查询数据
  • [containerd] 在Windows上使用IDEA远程调试containerd, ctr, containerd-shim
  • Verilog语法学习——LV4_移位运算与乘法
  • 打卡力扣题目九
  • Python零基础入门(九)——函数,类和对象