poj 2377 拉最长的线问题 kruskal算法
Posted xuxiaojin
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了poj 2377 拉最长的线问题 kruskal算法相关的知识,希望对你有一定的参考价值。
题意:建光纤的时候,拉一条最长的线
思路:最大生成树
- 将图的n个顶点看成n个孤立的连通分支,并将所有的边按权从大到小排
- 边权递减的顺序,如果加入边的两个端点不在同一个根节点的话加入,并且要将其连通,否则放弃
- 最后剩下一个连通支
解决问题的代码:
#include<cstdio> #include<iostream> #include<cstring> #include<algorithm> #include<cmath> #include<vector> #include<queue> #include<map> #include<set> #include<ctime> using namespace std; typedef long long ll; #define maxn 1111 #define maxm 22222 struct node { int u,v,w; }edge[maxm]; int T,n,m,fa[maxn]; int cmp(node a,node b) { return a.w>b.w; } int find(int x) { if(fa[x]==x) return x; return fa[x]=find(fa[x]); } int kruskal(int n,int m) { for(int i=1;i<=n;i++)fa[i]=i; int ans=0,cnt=0; sort(edge,edge+m,cmp); for(int k=0;k<m;k++) { int x=find(edge[k].u),y=find(edge[k].v); if(x!=y) { cnt++; fa[x]=y; ans+=edge[k].w; if(cnt==n-1)return ans; } } return -1; } int main() { while(~scanf("%d%d",&n,&m)) { for(int i=0;i<m;i++)scanf("%d%d%d",&edge[i].u,&edge[i].v,&edge[i].w); printf("%d ",kruskal(n,m)); } return 0; }
以上是关于poj 2377 拉最长的线问题 kruskal算法的主要内容,如果未能解决你的问题,请参考以下文章
POJ 2377 Bad Cowtractors (Kruskal)
ZOJ 1542 POJ 1861 Network 网络 最小生成树,求最长边,Kruskal算法