WikiOI 1231 最优布线问题

这个问题让无数人崩溃,而且没有标程。我来贡献一个吧。。。。。。(从网上的标准kruskal+并查集代码改的)(我不会并查集)

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
struct self{int x,y;long long c;};
self s[1000001];
int a,b,m,n;
long long z=0;
int f[1000001];
int use[1000001];
bool firstuse[1000001]={0}; 

int find(int i)
{
return f[i]==i?i:f[i]=find(f[i]);
} 

int cmp(self a1,self a2)
{
return a1.c<a2.c;
}

long long kruskal1()
{
long long z=0;
int y=0;
for(int k=1;k<=n;k++)
{
int l=find(s[k].x);
int r=find(s[k].y);
if(l!=r)
{
firstuse[k]=1;
f[l]=r;
z+=s[k].c;
y++;
if(y==m-1)return z;

}
} 
return z;
}

long long kruskal()
{
long long z=0;
int y=0;
for(int k=1;k<=n;k++)
if(use[k])
{
int l=find(s[k].x);
int r=find(s[k].y);
if(l!=r)
{
f[l]=r;
z+=s[k].c;
y++;
if(y==m-1)return z;
}

} 
return z;
}

int main()
{
scanf("%d %d",&m,&n);
for(a=1;a<=n;a++)
{
f[a]=a;
scanf("%d %d %d",&s[a].x,&s[a].y,&s[a].c);
use[a]=1;
}
sort(s+1,s+n+1,cmp);

if(n<m-1)
{
printf("-1\n");
return 0;
}

z=kruskal();
printf("%lld\n",z);
return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值