再次探讨最小生成树Prim算法

二次复习Prim算法时得到了一些新的启示。正常初次学算法时都特别注意代码,但是慢慢的发现,随着代码能力的增强,代码反而不是这么重要,重要的是算法的思路。既在自己的脑子中能有这个算法的图解。

下面展示一下二次学习的思路:

假设连通网G={VE},图T={UME}是图G的最小代价生成树,求图T的步骤如下:

(1)U={u0}ME={φ},u0是集合V****中的任意一个顶点。

(2)在所有的u∈U**,v∈V-U,而且****(u,v)∈E的边中,找一条权最小的边(uivi),将vi并入集合U,将边****(uivi)并入集合ME。**

(3)重复步骤2**,直到U=V。**

说白了就是这个意思:

1)先随便找一个点,加入集合R

2)在没有加入集合R的点中找到一个"距离集合R"距离最短的点,将其加入集合。注意:这个最短的距离(就是边,要把这个边记住)

3)如果还有没有加入集合的点,那么重复Step(2)。

这个算法是适用于"稠密图"(适合用邻接矩阵存储)。算法时间复杂度为O(n^2)。也可以用堆进行优化。具体想看代码请转到图论-最小生成树-CSDN博客

相关推荐
繁依Fanyi5 分钟前
828华为云征文|华为Flexus云服务器搭建OnlyOffice私有化在线办公套件
服务器·开发语言·前端·python·算法·华为·华为云
码了三年又三年30 分钟前
【算法】滑动窗口—最小覆盖子串
算法
AIAdvocate31 分钟前
力扣-96.不同的二叉搜索树 题目详解
python·算法·动态规划
说好不能打脸31 分钟前
利用模糊综合评价法进行数值评分计算——算法过程
算法
小周的C语言学习笔记33 分钟前
鹏哥C语言33---循环语句 for
c语言·c++·算法
shylyly_36 分钟前
归并排序
数据结构·算法·归并排序·递归归并排序·非递归归并排序
luthane37 分钟前
python 实现entropy熵算法
python·算法·概率论
X BoHang37 分钟前
洛谷 P4683 [IOI2008] Type Printer
算法
ZH_qaq1 小时前
【洛谷】P11062 【MX-X4-T2】「Jason-1」加法 的题解
c++·算法
Chase-Hart1 小时前
【每日一题】LeetCode 1184.公交站间的距离问题(数组)
java·算法·leetcode·eclipse·intellij-idea