最小生成树Prim算法 Kruskal算法
Prim算法(贪心策略)N^2
选定图中任意定点v0,从v0开始生成最小生成树
树中节点Va,树外节点Vb
最开始选一个点为Va,其余Vb,
之后不断加Vb到Va最短距离的点
1.初始化d[v0]=0,其他d[i]=正无穷。d表示Vb电到i的最小距离
2.经过n次如下步骤,得到一颗喊n节点n-1边的最小生成树
(1)选择一个未标记的k,并且d[k]的值最小
(2)标记点k进入树Va
(3)以k为中间点,修改未标记的点j,即Vb中的点到Va的距离值;
3.得到最小生成树t
#include<iostream>
#include<iomanip>
#include<cstring>
using namespace std;
const int INF=0x7fffffff/;
int vst[];//标记i是否加入最小生成树Va中
int d[];//i与当前生成树中的点有连边的边长最小值
int g[][],n,m,ans=;//g存边和权值
void read(){//读入数据
int i,j,x,y,w;
cin>>n>>m;//n点m边
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
g[i][j]=INF;//清零
for(i=;i<=m;i++){
cin>>x>>y>>w;
g[x][y]=g[y][x]=w;//记录边和权值
}
}
void prim(int v0){
int i,j,k,minn;
memset(vst,,sizeof(vst));
for(i=;i<=n;i++) d[i]=INF;//初始化
d[v0]=;//最初节点
ans=;
for(i=;i<=n;i++){//选择n个点
minn=INF;
for(j=;j<=n;j++)//选择最小边 ,Vb到Va
if(vst[j]==&&minn>d[j]){
minn=d[j];k=j;
}
vst[k]=;//标记 ,加入到Va
ans+=d[k];//加上边的权值
for(j=;j<=n;j++)//修改d数组
if(vst[j]==&&d[j]>g[k][j])
d[j]=g[k][j];
}
}
int main(){
read();
prim();
cout<<ans<<endl;
return ;
}
Kruskal算法(贪心策略)nlogn
算法步骤:
1.将G中的带权边由小到大排序
2.按照权值由小到大依次选边。诺形成环就放弃这一条,否则标记当前边并计数;
3.重复2.直到生成树有n-1条边。
否则遍历完边取不到n-1,就不存在最小生成树。
***如何判断环:用并查集:判断新加入的边的两个端点如果在并查集同一集合则成环;
否则保存当前边,并合并涉及的两个集合。
#include<iostream>
#include<algorithm>
using namespace std;
const int maxn=;
struct edge{
int x,y,z;
}a[maxn];
int n,m,prt[maxn],ans=,bj;
bool cmp(const edge &x,const edge &y){
return x.z<y.z;
}
int getfather(int x){//找祖先
if(prt[x]==x) return x;
prt[x]=getfather(prt[x]);
return prt[x];
}
void kruskal(){//核心程序
int f1,f2,k,i;
k=;//记录已经加入的边数
for(i=;i<=n;i++) prt[i]=i;//初始化
for(i=;i<=m;i++){
f1=getfather(a[i].x);//并查集??不太懂
f2=getfather(a[i].y);
if(f1!=f2){
ans+=a[i].z;
prt[f1]=f2;//合并不相同的两个集合
k++;
if(k==n-) break;
}
}
if(k<n-){
cout<<"Impossible"<<endl;bj=;
return ;
}
}
int main(){
cin>>n>>m;
ans=;bj=;
for(int i=;i<=m;i++)
cin>>a[i].x>>a[i].y>>a[i].z;
sort(a+,a+m+,cmp);
kruskal();
if(bj) cout<<ans<<endl;
return ;
}
最小生成树Prim算法 Kruskal算法的更多相关文章
- 无向带权图的最小生成树算法——Prim及Kruskal算法思路
边赋以权值的图称为网或带权图,带权图的生成树也是带权的,生成树T各边的权值总和称为该树的权. 最小生成树(MST):权值最小的生成树. 生成树和最小生成树的应用:要连通n个城市需要n-1条边线路.可以 ...
- [数据结构]最小生成树算法Prim和Kruskal算法
最小生成树 在含有n个顶点的连通图中选择n-1条边,构成一棵极小连通子图,并使该连通子图中n-1条边上权值之和达到最小,则称其为连通网的最小生成树. 例如,对于如上图G4所示的连通网可以有多棵权值总 ...
- 图的最小生成树的理解和实现:Prim和Kruskal算法
最小生成树 一个连通图的生成树是一个极小的连通子图,它含有图中所有的顶点,但只有足以构成一棵树的n-1条边.我们将构造连通网的最小代价生成树称为最小生成树(Minimum Cost Spanning ...
- 最小生成树(Prim算法+Kruskal算法)
什么是最小生成树(MST)? 给定一个带权的无向连通图,选取一棵生成树(原图的极小连通子图),使生成树上所有边上权的总和为最小,称为该图的最小生成树. 求解最小生成树的算法一般有这两种:Prim算法和 ...
- hdu 1233 还是畅通工程 最小生成树(prim算法 + kruskal算法)
还是畅通工程 Time Limit: 4000/2 ...
- 最小生成树 Prim算法 Kruskal算法实现
最小生成树定义 最小生成树是一副连通加权无向图中一棵权值最小的生成树. 在一给定的无向图 G = (V, E) 中,(u, v) 代表连接顶点 u 与顶点 v 的边(即,而 w(u, v) 代表此边的 ...
- 算法(图论)——最小生成树及其题目应用(prim和Kruskal算法实现)
题目 n个村庄间架设通信线路,每个村庄间的距离不同,如何架设最节省开销? Kruskal算法 特点 适用于稀疏图,时间复杂度 是nlogn的. 核心思想 从小到大选取不会产生环的边. 代码实现 代码中 ...
- 【431】Prim 算法 & Kruskal 算法
Prim 算法: Minimum Spanning Tree(MST):最小生成树,就是连接所有节点的最小权值 mst集合与rest集合 mst集合中顶点,找到一条最小权值的边 然后把边相关的顶点,选 ...
- 最小生成树之算法记录【prime算法+Kruskal算法】【模板】
首先说一下什么是树: 1.只含一个根节点 2.任意两个节点之间只能有一条或者没有线相连 3.任意两个节点之间都可以通过别的节点间接相连 4.除了根节点没一个节点都只有唯一的一个父节点 5.也有可能是空 ...
随机推荐
- Java用户注册代码
<div class="registerbox"> <sf:form class="form-Register" name="for ...
- 如何编写linux下nand flash驱动-3
[读(read)操作过程详解] 以最简单的read操作为例,解释如何理解时序图,以及将时序图 中的要求,转化为代码. 解释时序图之前,让我们先要搞清楚,我们要做的事情:那就是,要从nand flash ...
- asp.net MVC Model 类的主键 int类型、string类型、GUID类型。
在使用asp.net mvc进行定义 模型类的时候,一般情况下,我们都会定义一个属性为 int iD{get;set;} 或为int ClassNameID {get;set;},在这种情况下 1.I ...
- 11_传智播客iOS视频教程_NS前缀和@符号
NS前缀的有NSLog和NSString Cocoa就是用来开发带界面的应用程序. Foundation框架之中的类.函数绝大多数都是从NextStep来的.看到NS前缀就知道这个类是从哪里来的.是很 ...
- Properties 文件的简单操作
properties 文件里面主要 存 一个Key对应一个Value 一般用来存放账户密码资料 方法有:Properties p=new Properties(); p.setproperty(& ...
- 【Aizu - 0005 】GCD and LCM
GCD and LCM Descriptions: Write a program which computes the greatest common divisor (GCD) and the l ...
- Luogu P1638 逛画展 【二分答案】
题目描述 博览馆正在展出由世上最佳的 M 位画家所画的图画. wangjy想到博览馆去看这几位大师的作品. 可是,那里的博览馆有一个很奇怪的规定,就是在购买门票时必须说明两个数字, a和b,代表他要看 ...
- 《windows核心编程系列》二十一谈谈基址重定位和模块绑定
每个DLL和可执行文件都有一个首选基地址.它表示该模块被映射到进程地址空间时最佳的内存地址.在构建可执行文件时,默认情况下链接器会将它的首选基地址设为0x400000.对于DLL来说,链接器会将它的首 ...
- Latex新人教程
1.LaTeX软件的安装和使用 方法A(自助):在MikTeX的官网下载免费的MikTeX编译包并安装.下载WinEdt(收费)或TexMaker(免费)等编辑界面软件并安装. 方法B(打包):在ct ...
- 洛谷 P2056 [ZJOI2007]捉迷藏 || bzoj 1095: [ZJOI2007]Hide 捉迷藏 || 洛谷 P4115 Qtree4 || SP2666 QTREE4 - Query on a tree IV
意识到一点:在进行点分治时,每一个点都会作为某一级重心出现,且任意一点只作为重心恰好一次.因此原树上任意一个节点都会出现在点分树上,且是恰好一次 https://www.cnblogs.com/zzq ...