hdu1839(最小生成树)

时间:2022-01-23 21:55:50

题意:字面意思;

思路:就是多了一个前提,有些点之间可能有边,有两个处理方法,一个是有边的,这条边权值归零,另一个是,先一次循环用并查集过一遍;

代码:(用的是第一种方法)

#include<iostream>
#include<algorithm>
#include<cstdio>
using namespace std;
struct node
{
int x;int y;int s;int v;
}edge[];
int f[];
int cmp(node a,node b)
{
return a.s<b.s;
}
int findf(int x)
{
if(f[x]==x)
return f[x];
else
{
f[x]=findf(f[x]);
return f[x];
}
}
bool join(int x,int y)
{
int t1,t2;
t1=findf(x);
t2=findf(y);
if(t1==t2)
return true;
else
{
f[t2]=t1;
return false;
}
}
int main()
{
int n;
int sum;
while(scanf("%d",&n)!=EOF)
{
sum=;
if(n==)
break;
for(int i=;i<=n;i++)
f[i]=i;
int m=n*(n-);m=m/;
for(int i=;i<=m;i++)
{
scanf("%d%d%d%d",&edge[i].x,&edge[i].y,&edge[i].s,&edge[i].v);
if(edge[i].v==)
edge[i].s=;
}
sort(edge+,edge++m,cmp);
for(int i=;i<=m;i++)
{
if(!join(edge[i].x,edge[i].y))
sum+=edge[i].s;
}
printf("%d\n",sum);
}
return ;
}