思路:
稳稳的Kruskal求最小生成树模板,好写效率也高,我们都爱用它~
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int inf=0x3f3f3f3f;
const int Max_v=110;
const int Max_e=11000;
struct edge{
int from,to,cost;
bool operator<(const edge& e)const{
return cost<e.cost;
}
}e[Max_e];
int V,E;
int par[Max_v];
int Find(int x){
if(par[x]==x)return x;
return par[x]=Find(par[x]);
}
int Kruskal(){
int sum=0;
for(int i=0;i<V;i++)par[i]=i;
sort(e,e+E);
for(int i=0;i<E;i++){
int x=Find(e[i].from);
int y=Find(e[i].to);
if(x!=y){
sum+=e[i].cost;
par[x]=y;
}
}
return sum;
}
int main()
{
while(~scanf("%d",&V)&&V!=0){
scanf("%d",&E);
int a,b,c;
for(int i=0;i<E;i++){
scanf("%d%d%d",&a,&b,&c);
e[i].from=a-1;e[i].to=b-1;
e[i].cost=c;
}
printf("%d\n",Kruskal());
}
return 0;
}