Kruskal算法

Kruskal算法是一种用来寻找最小生成树的算法之一。
该算法需要用到两个数据结构:

  1. 存储边的顶点和权值的数据结构
  2. 并查集
    在这里插入图片描述

图的存储结构:
(0,1)1
(2,4)2
(3,5)3
(1,4)4
(0,2)5
(0,3)6
(2,3)7
(1,2)8
(4,5)9

并查集:
0 0
1 1
2 2
3 3
4 4
5 5
算法步骤:

  1. 对图的存储结构,按照权值,从小到大排序。
  2. 对并查集进行初始化,即把每一个位置中的值初始化为其对应下标。
  3. 选取存储结构的最小项,查询该边所对应的顶点在并查集中是否同源,同源则进行5,不同于则进行4.
  4. 若不同源,则把该边加入生成树,并计算和,修改前者的根在并查集中位置的值为后者的根。
  5. 若同源,则跳过,继续遍历剩余数据结构。

通过Kruskal算法之后:
在这里插入图片描述
此时
图的存储结构:
(0,1)1
(2,4)2
(3,5)3
(1,4)4
(0,2)5
(0,3)6
(2,3)7
(1,2)8
(4,5)9

并查集:
0 1
1 4
2 4
3 5
4 5
5 5

该算法适用于简单图

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值