最小生成树(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; }
此外还有适合稠密图的prim算法,以后再学----
没有AC不了的题,只有不努力的ACMER!