【图论笔记】克鲁斯卡尔算法(Kruskal)求最小生成树

【图论笔记】克鲁斯卡尔算法(Kruskal)求最小生成树

适用于

克鲁斯卡尔适合用来求边比较稀疏的图的最小生成树

简记:

将边按照升序排序,选取n-1条边,连通n个顶点。

添加一条边的时候,如何判断能不能添加这条边?(添加进来之后,会不会构成回路)

看标记,

和原来的标记不一样,就可以加入,

加入之后将他们的标记修改为一样的。

图解

第一步:创建一个连通图,并且给每个顶点都标记上不同的颜色

第二步:选取边<A,C>,选完之后C的颜色要和A相同

第三步:加入边<D,F>,将F的颜色改为D的蓝色

第四步:加入边<B,E>,将E改为紫色

第五步:添加边<C,F>,将F相连的节点改为绿色(包括它自己)

第六步:<A,D>不能加入,因为A和D的颜色一样。加入边<B,C>,将原来和B相连的节点的颜色都改为绿色。完

代码正在研究

相关推荐
YGGP9 小时前
【Golang】LeetCode 279. 完全平方数
算法·leetcode
im_AMBER9 小时前
Leetcode 87 等价多米诺骨牌对的数量
数据结构·笔记·学习·算法·leetcode
import_random10 小时前
[算法]时间序列(介绍)
算法
wuk99810 小时前
MATLAB中求解和分析马蒂厄方程
人工智能·算法·matlab
今儿敲了吗10 小时前
计算机网络第一章笔记
笔记·计算机网络
Wang2012201310 小时前
LSTM和Transformer对比
人工智能·算法·架构
KingRumn10 小时前
Linux进程间通信之D-Bus
linux·算法
yuxb7310 小时前
Jenkins 流水线:镜像仓库与自动化部署
笔记·jenkins
fufu031110 小时前
Linux环境下的C语言编程(四十九)
linux·c语言·算法
YGGP10 小时前
【Golang】LeetCode198. 打家劫舍
算法·leetcode