最小生成树---Prim---Kruskal
来源:互联网 发布:论文参考文献来自网络 编辑:程序博客网 时间:2024/05/17 08:18
最小生成树之prim算法
最小生成树(MST):权值最小的生成树。
MST性质:假设G=(V,E)是一个连通网,U是顶点V的一个非空子集。若(u,v)是一条具有最小权值的边,其中u∈U,v∈V-U,则必存在一棵包含边(u,v)的最小生成树。
prim算法
基本思想:假设G=(V,E)是连通的,TE是G上最小生成树中边的集合。算法从U={u0}(u0∈V)、TE={}开始。重复执行下列操作:
在所有u∈U,v∈V-U的边(u,v)∈E中找一条权值最小的边(u0,v0)并入集合TE中,同时v0并入U,直到V=U为止。
此时,TE中必有n-1条边,T=(V,TE)为G的最小生成树。
Prim算法的核心:始终保持TE中的边集构成一棵生成树。
注意:prim算法适合稠密图,其时间复杂度为O(n^2),其时间复杂度与边得数目无关,而kruskal算法的时间复杂度为O(eloge)跟边的数目有关,适合稀疏图。
看一个例子:
在看一个例子:
Kruskal算法
1.概览
Kruskal算法是一种用来寻找最小生成树的算法,由Joseph Kruskal在1956年发表。用来解决同样问题的还有Prim算法和Boruvka算法等。三种算法都是贪婪算法的应用。和Boruvka算法不同的地方是,Kruskal算法在图中存在相同权值的边时也有效。
2.算法简单描述
1).记Graph中有v个顶点,e个边
2).新建图Graphnew,Graphnew中拥有原图中相同的e个顶点,但没有边
3).将原图Graph中所有e个边按权值从小到大排序
4).循环:从权值最小的边开始遍历每条边 直至图Graph中所有的节点都在同一个连通分量中
if 这条边连接的两个节点于图Graphnew中不在同一个连通分量中
添加这条边到图Graphnew中
代码实现:
- Prim、Kruskal最小生成树
- 最小生成树---Prim---Kruskal
- 最小生成树 Kruskal&&Prim
- 最小生成树 Prim Kruskal
- Kruskal/prim--最小生成树
- 最小生成树 PRIM KRUSKAL
- 最小生成树算法(prim&kruskal)
- 最小生成树poj1258 prim和kruskal
- Prim和Kruskal最小生成树
- HDU 1233 prim kruskal最小生成树
- HDU 1879 最小生成树 prim + kruskal
- 最小生成树--Prim和Kruskal算法
- 最小生成树-Kruskal算法-Prim算法
- 最小生成树(Prim和Kruskal)
- 最小生成树(Kruskal+Prim)
- HDU3371-最小生成树-Kruskal-Prim
- 最小生成树-Prim及Kruskal
- [POJ2421]最小生成树+PRIM+KRUSKAL
- MongoDB基本操作
- 阿里云搭建网站全步骤
- Kernel中bluetooth相关的config选项
- iOS 推送证书设置
- SpringMVC-提高篇-UerExcep.java
- 最小生成树---Prim---Kruskal
- 一种新型的IP VPN技术
- linux下vi命令大全
- Android休眠对心跳中断带来的影响
- 第八周项目5-计数的模式匹配
- Apple iOS推送证书配置和生成教程
- 最值钱跳槽时间点和全国高薪城市出炉!
- java代码转换成smali代码
- 为Android硬件抽象层(HAL)模块编写JNI方法提供Java访问硬件服务接口