kruskal算法的精髓在于:
每次选取一条边。
该边同时满足:1、在当前未选边中权值最小;2、与已选边不构成回路。
直到选取n-1条表是算法结束。找到MST活判断不存在MST。
代码设计:
1、利用优先级队列将权值小的边放到队列最前,优先出对,保证了每次选择的都是权值最小的边。
2、利用并查集的查找及结合把同处同一连通分量中的顶点连到同一父节点下。这样,每次判断是
否构成回路,只要判断父节点是否相同的即可。
代码:
#include<iostream>
#include<cmath>
#include<queue>
using namespace std;
const int maxn=101; //图的最大节点数
struct edge //边
{
int from; //起点
int to; //终点
int cost; //路径长
friend bool operator < (const edge &e1,const edge &e2)
{
return e1.cost>e2.cost;
}
};
edge remMST[maxn]; //记录组成最小生成树的边
int father[maxn]; //用来做并查集
int nodeNum,edgeNum; //顶点数、边数
int MST; //最小生成树
priority_queue<edge> myQ; //kruskal算法,存放边
void storeMap() //存储岛的桥构成的图
{
while(!myQ.empty()) myQ.pop(); //清空
int from,to,cost;
for(int i=0;i<edgeNum;i++)

Kruskal算法是寻找图的最小生成树的一种方法,关键在于选择最小权值的边且避免形成环路。通过优先级队列保证边的选择顺序,并使用并查集判断是否构成环路。本文介绍了Kruskal算法的详细步骤,提供了代码实现,并给出了测试实例。
最低0.47元/天 解锁文章
1975

被折叠的 条评论
为什么被折叠?



