标签:using cti type find 代码 题意 main 顶点 放弃
题意:建光纤的时候,拉一条最长的线
思路:最大生成树
解决问题的代码:
#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\n",kruskal(n,m)); } return 0; }
标签:using cti type find 代码 题意 main 顶点 放弃
原文地址:https://www.cnblogs.com/xuxiaojin/p/9407962.html