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

最小生成树

最小生成树即用最少的边权将所有给定的点连在同一联通分量中,常用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算法,以后再学----

 

你可能感兴趣的:(最小生成树)