最小生成树(java实现)带注释

本文介绍了最小生成树的概念,它在连通图中寻找总权值最小的生成树。 Prim算法作为求解最小生成树的经典算法之一,通过详细步骤解释其执行过程。文章还提及了切分定理,强调横切边中权值最小的边在最小生成树中的重要性。
摘要由CSDN通过智能技术生成

最小生成树(Minimum Spanning Tree)

  • 简称MST
    • 也成为最小权重生成树(Minimum Weight Spanning Tree)、最小支撑树
    • 是所有生成树中,总权值最小的那棵
    • 适用于有权的连通图(无向)

在这里插入图片描述

例子
  • 最小生成树在许多领域都有重要的作用,例如
    • 要在n个城市之间铺设光缆,使它们都可以通信
    • 铺设光缆的费用很高,且各个城市之间因为距离不同等因素,铺设光缆的费用也不同
    • 如何使铺设光缆的总费用最低?
  • 如果图的每一条边的权值都互不相同,那么最小生成树将只有一个,否则可能会有多个最小生成树
  • 求最小生成树的2个经典算法
    • Prim(普里姆算法)
    • Kruskal(克鲁斯克尔算法)
切分定理
  • 切分(Cut):把图中的节点分为两部分,称为一个切分

  • 下图有个切分C=(S,T),S={A,B,D},T={C,E}

在这里插入图片描述

  • 横切边(CrossingEdge):如果一个边的两个顶点,分别属于切分的两部分,这个边称为横切边

  • 切分定理:给定任意切分,横切边中权值最小的边必然属于最小生成树

prim算法-执行过程
  • 假设G=(V,E)是有权的连通图(无向),A是G中最小生成树的边集
    • 算法从S={uo}(uoEV),A={}开始,重复执行下述操作,直到S=V为止
      1. 找到切分C=(S,V-S)的最小横切边(uo,vo)并入集合A,同时将vo并入集合S
        在这里插入图片描述
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值