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

最小生成树(kruskal+并查集)

时间:2015-03-11 16:35:21      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:

最小生成树

最小生成树即用最少的边权将所有给定的点连在同一联通分量中,常用kruskal和prim算法

kruskal算法(适合稀疏图)

技术分享
最小生成树的kruskal算法,稍带并查集的应用

int find(int x)
{
    return fa[x]==x?x:fa[x]=find(fa[x]); //不要漏了fa[x]=...
}

int kruskal()
{
    int ans=0;
    for(int i=0;i<N;i++) fa[i]=i;//初始化并查集
    sort(edge,edge+e);  //将边进行排序
    for(int i=0;i<e;i++){
        int x=find(edge[i].u),y=find(edge[i].v); //从小边开始逐渐生成数
        if(x!=y){
            fa[x]=y;
            ans+=edge[i].cost;
        }
    }
    return ans;
}
kruskal算法

此外还有适合稠密图的prim算法,以后再学----

 

最小生成树(kruskal+并查集)

标签:

原文地址:http://www.cnblogs.com/--560/p/4330004.html

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