并查集与克鲁斯卡尔算法详解

并查集的常见用途:求连通子图;克鲁斯卡尔算法;求最近公共祖先

三个基本操作:(1)makeSet:建立一个新的并查集,其中包含s个单元素的集合;

(2)unionSet(x,y):把元素x和y所在的集合合并,并且x,y所在的集合不相交,如果相交则不合并;

(3)find(x):找到x所在的集合的代表,该操作可以用于判断两个元素是否位于同一个集合,只要比较它们各自集合的代表就可以;(什么是集合的代表)?

实现:用树来表示集合,树的每个结点就表示集合中的一个元素,树根对应的元素就是该集合的代表。

树的结点表示集合中的元素,指针表示指向父节点的指针,根结点的指针指向自己,表示其没有父节点。沿着每个节点的父节点不断向上查找,最终就可以找到根结点,也就是该集合的代表元素;

makeSet:就是建立一个数组,并赋初值,利用循环;

find 操作:如果每次都沿着父节点向上查找,那么时间复杂度就是树的高度,不可能达到常数级;

我们在这里需要采用一种策略:——路径压缩

路径压缩就体现在将所有的节点的父亲节点都变为根结点;

unsionSet操作:并查集的合并,就是将一个集合的树根指向另一个集合的树根;

合并的原则:按秩合并,使用秩来表示树高度的上界,在合并时,总是将具有较小秩的树根指向具有较大秩的树根,简单的说就是总是将比较矮的树作为子树,添加到较高的树中,为了保存秩,需要额外使用一个与uset同长度的数组,并将所有的元素都初始化为0;//这个秩不太好理解;

第二种方式:按集合中包含的元素个数(或者说树中的节点数)合并,将包含节点较少的树根,指向包含节点较多的树根。这个策略与按秩合并的策略类似,同样可以提升并查集的运行速度,而且省去了额外的 rank 数组。

这样的并查集具有一个略微不同的定义,即若 uset 的值是正数,则表示该元素的父节点(的索引);若是负数,则表示该元素是所在集合的代表(即树根),而且值的相反数即为集合中的元素个数。相应的代码如下所示,同样包含递归和非递归的 find 操作:

这里不需要设立rank数组;

void UFset() // 初始化{for (int i = 0; i < n; i ++)parent[i] = -1;}int Find(int x)  // 查找并返回结点x所属集合的根结点{int s;    // 查找位置for (s = x; parent[s]>=0; s = parent[s]);  // 注意这里的 ;while (s != x)   // 优化方案 -- 压缩路径,使后续的查找{int tmp = parent[x];parent[x] = s;x = tmp;}return s;}// R1和R2是两个元素,属于两个不同的集合,现在合并这两个集合void Union (int R1, int R2){// r1位R1的根结点,r2位R2的根结点int r1 = Find(R1), r2 = Find(R2);int tmp = parent[r1] + parent[r2];   // 两个集合的结点个数之和(负数)//每添加一个节点,就将其parent更新为tmp,也就意味着其个数增加1;//一个边对应两个点,每次只对两个点进行操作,所以可以加1;只更新顶点的parent,//一开始是所有的顶点都可以作为集合的代表// 如果R2所在树结点个数 > R1所在树结点个数// 注意parent[r1]和parent[r2]都是负数if(parent[r1] > parent[r2])    // 优化方案 -- 加权法则{parent[r1] = r2;        // 将根结点r1所在的树作为r2的子树(合并)parent[r2] = tmp;       // 跟新根结点r2的parent[]值}else{parent[r2] = r1;         // 将根结点r2所在的树作为r1的子树(合并)parent[r1] = tmp;        // 跟新根结点r1的parent[]值}}

二.克鲁斯卡尔算法

最小生成树之克鲁斯卡尔(Kruskal)算法 - gaoyanliang - 博客园 (cnblogs.com)

但是其实并查集只是按照顺序加边,没有比较边的权值这一过程,所以如果我们按照边的值从小到达进行排列的话,我们就只需要前面几条较小的边就能将所有的节点连接起来,最终得到最小的生成树;

sort函数的实现:根据cmp的结果,设置:是否交换

//在C语言中:利用qsort函数,直接对edge类型的数组中的weigjt进行排序;

#include <stdio.h> #include <stdlib.h> // 假设edges是一个整数数组,我们要根据整数的大小进行排序 int cmpfunc(const void *a, const void *b){ return (*(int*)a - *(int*)b); } int main() { int edges[] = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5}; int m = 5; // 假设我们只想对前5个元素进行排序 // 注意:qsort会排序整个数组,但我们可以通过调整传入的元素数量来限制它的范围// 由于qsort没有直接的“开始索引”和“结束索引”参数,我们通常传递整个数组,但只在比较函数中处理我们关心的部分// 如果我们真的只想对前m个元素进行排序,并且这些元素之后的数据我们不想改变, // 那么我们需要复制前m个元素到一个新数组,对新数组进行排序,然后再复制回去。 // 但这里为了简单起见,我们直接对整个数组进行排序。// 使用qsort进行排序 qsort(edges, sizeof(edges) / sizeof(edges[0]), sizeof(int), cmpfunc); // 打印排序后的数组 for(int i = 0; i < sizeof(edges) / sizeof(edges[0]); i++) { printf("%d ", edges[i]); } return 0; }

在这里u,v表示的时一个边的两个顶点//——体现加边法这一特点;

因此在for循环中,循环的次数最多的给的是m——即为图的边数,而不是顶点数,区别于普利姆算法;

直到所有的顶点都加入到了一个集合中;

所以只要把并查集搞清楚,就能很容易地实现克鲁斯卡尔算法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/22645.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

弘君资本:半导体板块强势拉升,上海贝岭涨停,台基股份等大涨

半导体板块5日盘中强势拉升&#xff0c;到发稿&#xff0c;台基股份涨超15%&#xff0c;中晶科技、上海贝岭等涨停&#xff0c;国科微、长川科技涨超7%&#xff0c;紫光国微、富满微、金海通等涨超5%。 组织表示&#xff0c;半导体职业处于历史较低水平&#xff0c;大基金三期…

Ansible自动化运维工具 playbook 剧本

一、Playbooks 1. playbooks 介绍 Playbooks&#xff08;剧本&#xff09;是一种用于定义自动化任务的文件&#xff0c;通常与诸如Ansible等工具相关联。它们以YAML格式编写&#xff0c;包含了一系列有组织的任务&#xff0c;这些任务可以在远程计算机上执行。一个Playbook通…

微信小程序毕业设计-在线订餐系统项目开发实战(附源码+论文)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;微信小程序毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计…

微服务学习Day9-分布式事务Seata

文章目录 分布式事务seata引入理论基础CAP定理BASE理论 初识Seata动手实践XA模式AT模式TCC模式SAGA模式 高可用 分布式事务seata 引入 理论基础 CAP定理 BASE理论 初识Seata 动手实践 XA模式 AT模式 TCC模式 Service Slf4j public class AccountTCCServiceImpl implements A…

mvsplat 的笔记

变量理解&#xff1a; context_image&#xff1a; 表示投影的 refrence image Epipolar Transformer vs Swin Transformer : 不同于 Pixel Splat 使用的是 Epipolar Transformer. MVspalt 使用的是 Swin Transformer&#xff0c; 但是作者在 Code 里面 也使用了 Epipolar Tran…

【Vue】v-model在其他表单元素的使用

讲解内容&#xff1a; 常见的表单元素都可以用 v-model 绑定关联 → 快速 获取 或 设置 表单元素的值 它会根据 控件类型 自动选取 正确的方法 来更新元素 输入框 input:text ——> value 文本域 textarea ——> value 复选框 input:checkbox ——> checked…

国内这些免费好用的saas软件你知道几个?

什么是saas软件&#xff1f; 软件即服务&#xff0c;或简称SaaS&#xff0c;是一种用于向用户提供软件的基于云的方法。软件即服务&#xff08;SaaS&#xff09;是一种基于云的软件模型&#xff0c;可通过Internet 浏览器将应用程序交付给最终用户。SaaS 供应商托管服务和应用程…

将现有web项目打包成electron桌面端教程

后续项目需要web端和桌面端&#xff0c;为了提高开发效率&#xff0c;准备直接将web端的代码打包成桌面端&#xff0c;在此提前记录一下demo打包的过程&#xff0c;我的项目是vue3tsvite&#xff0c;需要注意的是vue2或者vue3jsvite或者vue-cli的打包方式各不同&#xff0c;如果…

伏图(Simdroid)5.0 电子散热模块介绍

伏图-电子散热模块&#xff08;Simdroid-EC&#xff09;是云道智造基于通用多物理场仿真PaaS平台伏图开发的针对电子元器件、设备等散热的专用热仿真模块&#xff0c;内置电子产品专用零部件模型库&#xff0c;支持用户通过“搭积木”的方式快速建立电子产品的热分析模型&#…

Facebook开户|如何科学高效投放Facebook Ads

中午好家人们~今天Zoey来聊聊如何科学高效投放Facebook Ads~ 一、定义目标受众 在开始广告投放之前&#xff0c;需要明确定义你的目标受众。你可以根据受众的年龄、性别、兴趣、行为以及他们所在的地理位置等信息来确定目标受众。这样有助于创建精准的广告&#xff0c;并确保广…

下载Keil芯片包的方法

Keil里面弹出来的这个蓝色超链接&#xff0c;没梯子不要用edge浏览器 Arm Keil | Devices

对接专有钉钉(浙政钉)登陆步骤

背景 因为项目需要对接浙政钉&#xff0c;我想应该和之前对接阿里云的钉钉登陆钉钉登陆类似&#xff0c;就上网搜索看看&#xff0c;出现了个专有钉钉的概念&#xff0c;就一时间搞不清楚&#xff0c;钉钉&#xff0c;专有钉钉&#xff0c;浙政钉的区别&#xff0c;后续稍微理…

儿童护眼灯什么牌子好点?五款儿童护眼灯品牌推荐

儿童护眼灯什么牌子好点&#xff1f;根据往年的统计&#xff0c;我国青少年近视率位居世界第一&#xff0c;儿童青少年总体近视率达到了52.7%。其中&#xff0c;6岁儿童的近视率为14.5%&#xff0c;小学生为36.0%&#xff0c;初中生为71.6%&#xff0c;高中生为81%。造成近视的…

基于STM32的位置速度环PID控制伺服电机转动位置及程序说明

PID控制原理 PID控制原理是一种广泛应用于工业自动化和其他领域的控制算法。PID控制器的名字来源于其三个主要组成部分&#xff1a;比例&#xff08;Proportional&#xff09;、积分&#xff08;Integral&#xff09;和微分&#xff08;Derivative&#xff09;。PID控制器实现…

Go方法特性详解:简单性和高效性的充分体现

本文深入探讨了Go语言中方法的各个方面&#xff0c;包括基础概念、定义与声明、特性、实战应用以及性能考量。文章充满技术深度&#xff0c;通过实例和代码演示&#xff0c;力图帮助读者全面理解Go方法的设计哲学和最佳实践。 关注作者&#xff0c;分享互联网架构、云服务技术的…

excle中数据分析,excle导入用sql简单处理

前言&#xff1a; 办法一&#xff1a;直接用excle导入db就行&#xff0c;如果excle导如db不能用&#xff0c;就用笨办法下面这个方法去做 1、从系统中导出excle 2、db中插入相应的表和标题 3、先手动插入条件&#xff0c;把insert语句复制出来 INSERT INTO test.test (orders…

【人工智能】第五部分:ChatGPT的实际应用案例和未来发展方向

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

Linux基础 (十三):计算机网络基础概论

一、网络基本概念 1.1 网络 把独立自主的计算机通过传输介质和网络设备链接起来&#xff0c;就构成一个网络 &#xff0c;网络是由若干结点和连接这些结点的链路组成&#xff0c;网络中的结点可以是计算机&#xff0c;交换机、 路由器等设备。 网络设备有&#xff1a;交换机、…

名字能化解命中的劫数,你可知道?

老师&#xff0c;是我们全社会都要尊重的职业&#xff0c;教书育人培养着优秀人才。然而&#xff0c;在她人生最脆弱的时候&#xff0c;学校却解除了与她的劳动关系&#xff0c;再次给她“致命一击”&#xff0c;她所遭受的不公待遇和供职学校的冷漠&#xff0c;引发了社会极大…

【Vue】——前端框架的基本使用

&#x1f4bb;博主现有专栏&#xff1a; C51单片机&#xff08;STC89C516&#xff09;&#xff0c;c语言&#xff0c;c&#xff0c;离散数学&#xff0c;算法设计与分析&#xff0c;数据结构&#xff0c;Python&#xff0c;Java基础&#xff0c;MySQL&#xff0c;linux&#xf…