码迷,mamicode.com
首页 > 其他好文 > 详细

最小生成树

时间:2019-04-26 19:36:47      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:void   ++   clu   最小生成树   name   sort   lin   bsp   最小   

最小生成树是在n个点的图中选n-1条边构成树(每个点都满足能够互相达到,即直接连接或间接)

整一整kruskal

模板:

#include<bits/stdc++.h>
using namespace std;
int n,m;
int fa[5005];
inline int father(int t){
    if(fa[t]!=t) fa[t]=father(fa[t]);
    return fa[t];
}
inline void u(int l,int r){
    int fl=father(l);
    int fr=father(r);
    if(fl!=fr) fa[fl]=fr; 
}
struct ed{
    int len;
    int begin,end;
}dis[200005];
inline bool cmp(ed a,ed b){
    return a.len<b.len;
}
int sum;
int num;
int main(){
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
        fa[i]=i;
    for(int i=1;i<=m;i++){
        int x,y,z;
        scanf("%d%d%d",&x,&y,&z);
        dis[i].begin=x;
        dis[i].end=y;
        dis[i].len=z;
    }sort(dis+1,dis+1+m,cmp);
    for(int i=1;i<=m;i++){
        if(father(dis[i].begin)!=father(dis[i].end)){
            u(dis[i].begin,dis[i].end);
            sum+=dis[i].len;
            num++;
        }
        if(num==n-1){
            cout<<sum<<endl;
            return 0;
        }
    }
    cout<<"orz";
    return 0;
} 

 

最小生成树

标签:void   ++   clu   最小生成树   name   sort   lin   bsp   最小   

原文地址:https://www.cnblogs.com/648-233/p/10776111.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!