并查集的学习
创始人
2024-04-16 06:43:34
0

并查集是一种树型的数据结构,并查集可以高效地进行如下操作:

1、查询元素p和元素q是否属于同一组

2、合并元素p和元素q所在地组

 并查集结构:

是一种树型结构,这棵树地要求比较简单

1、每个元素都唯一对应一个节点

2、每一组数据中地多个元素都在同一棵树内

3、一个组中的数据对应的树和另外一个组中的数据对应的树之间没有任何联系

4、元素在树中没有子父级关系的硬性要求

 并查集的查找思路:

在数组中寻找,根据下标找到对应的元素,该元素如若不等于下标,则为该下标的父节点。当下标值等于对应下标元素的值,便是找到所要查找元素分组的标识符,思路图如下所示

 并查集的合并思路:

找到p,q的根节点,让p所在树的根节点的父节点为q的根节点即可:

 并查集的路径压缩优化(以上方法可能会生成线性树,使得查找的最大时间复杂度为On),为了降低查找的时间复杂度,

提高find的效率,我们可以在合并的时候,将小树合并到大树中,最大程度降低树的深度。

 

 最终并查集的代码结构如下所示

   public class UF{//记录节点元素和该元素所在分组的标识private int[] eleAndGroup;//记录并查集中数据的分组个数private int count;//用来存储每一个根节点对应树中保存的节点的个数private int[]sz;//初始化并查集public UF(int N){this.count=N;this.eleAndGroup=new int[N];for (int i = 0; i < eleAndGroup.length; i++) {eleAndGroup[i]=i;}this.sz=new int[N];//默认情况下,sz每个索引处的值都是1for(int i=0;i

相关内容

热门资讯

起诉闺蜜借款被驳回?平远法院审... 近日,平远法院审理了一起民间借贷纠纷。原告小洁起诉闺蜜小青,要求归还6000元借款,并提交了微信转账...
广西“上里西游记”表演团队走红... 在“上里西游记”的直播间,身穿红袈裟、骑着白马的“唐僧”跟着“孙悟空”和“猪八戒”走在前面,“沙和尚...
政策组合拳助力“十五五”良好开... 岁末年初,政策窗口期至关重要。 中央经济工作会议部署落定,国家发展改革委已率先行动,抢抓时间窗口,主...
思创医惠:收到杭州市公安局《移... 每经AI快讯,12月31日,思创医惠(300078.SZ)公告称,公司收到杭州市公安局出具的《移送审...
明星电力:员工生育严格执行国家... 有投资者在互动平台向明星电力提问:“您好,请问公司是否针对员工生育或育儿设有相关的福利或激励政策? ...
高科技产业商业秘密保护的挑战与... 一、高科技产业商业秘密纠纷频发 智能驾驶、芯片、动力电池等高科技产业,商业秘密纠纷频发。2025年7...
百利科技(603959)披露公... 截至2025年12月31日收盘,百利科技(603959)报收于5.74元,较前一交易日下跌1.88%...
2025年山西破获经济犯罪案件... 中新网太原12月31日电 (记者 李庭耀)记者31日从山西省公安厅获悉,2025年,山西警方累计破获...
澄星股份:为员工提供符合国家法... 有投资者在互动平台向澄星股份提问:“您好,请问公司是否针对员工生育或育儿设有相关的福利或激励政策? ...
成都市新都区举行劳动纠纷处置比... 近日,2025年“新工司南”主题交流活动暨成都市新都区劳动纠纷处置比武竞赛在四川科伦药业股份有限公司...