算法提升:图的最小生成树算法-克鲁斯卡尔(Kruskal)
创始人
2024-02-22 11:51:39
0

目录

概念

思路

代码


概念

克鲁斯卡尔算法查找最小生成树的方法是:将连通网中所有的边按照权值大小做升序排序,从权值最小的边开始选择,只要此边不和已选择的边一起构成环路,就可以选择它组成最小生成树。对于 N 个顶点的连通网,挑选出 N-1 条符合条件的边,这些边组成的生成树就是最小生成树。

举个例子,图 1 是一个连通网,克鲁斯卡尔算法查找图 1 对应的最小生成树,需要经历以下几个步骤:
 


图 1 连通网


1) 将连通网中的所有边按照权值大小做升序排序:
 


2) 从 B-D 边开始挑选,由于尚未选择任何边组成最小生成树,且 B-D 自身不会构成环路,所以 B-D 边可以组成最小生成树。
 


图 2 B-D 边组成最小生成树


3) D-T 边不会和已选 B-D 边构成环路,可以组成最小生成树:
 


图 3 D-T 边组成最小生成树


4) A-C 边不会和已选 B-D、D-T 边构成环路,可以组成最小生成树:
 


图 4 A-C 边组成最小生成树


5) C-D 边不会和已选 A-C、B-D、D-T 边构成环路,可以组成最小生成树:
 


图 5 C-D 边组成最小生成树


6) C-B 边会和已选 C-D、B-D 边构成环路,因此不能组成最小生成树:
 


图 6 C-B 边不能组成最小生成树


7) B-T 、A-B、S-A 三条边都会和已选 A-C、C-D、B-D、D-T 构成环路,都不能组成最小生成树。而 S-A 不会和已选边构成环路,可以组成最小生成树。
 


图 7 S-A 边组成最小生成树


8) 如图 7 所示,对于一个包含 6 个顶点的连通网,我们已经选择了 5 条边,这些边组成的生成树就是最小生成树。
 


图 8 最小生成树

思路

整个K算法中,其实简单的说就包含两个步骤:

  1. 找出路径中最短的边;
  2. 看这个边会不会对现有的边形成环路,如果会就丢弃,如果不会就记录;

难点就是判断会不会有环,这里可以使用到并查集的思想去做,也可以直接使用一个集合,把所有的节点放入集合,如果下一次选中的边两个节点都在集合中可以被找到,那就说明会导致环路。

代码

#include 
#include 
#define N 9   // 图中边的数量
#define P 6   // 图中顶点的数量
//构建表示边的结构体
struct edge {//一条边有 2 个顶点int initial;int end;//边的权值int weight;
};//qsort排序函数中使用,使edges结构体中的边按照权值大小升序排序
int cmp(const void* a, const void* b) {return  ((struct edge*)a)->weight - ((struct edge*)b)->weight;
}
//克鲁斯卡尔算法寻找最小生成树,edges 存储用户输入的图的各个边,minTree 用于记录组成最小生成树的各个边
void kruskal_MinTree(struct edge edges[], struct edge minTree[]) {int i, initial, end, elem, k;//每个顶点配置一个标记值int assists[P];int num = 0;//初始状态下,每个顶点的标记都不相同for (i = 0; i < P; i++) {assists[i] = i;}//根据权值,对所有边进行升序排序qsort(edges, N, sizeof(edges[0]), cmp);//遍历所有的边for (i = 0; i < N; i++) {//找到当前边的两个顶点在 assists 数组中的位置下标initial = edges[i].initial - 1;end = edges[i].end - 1;//如果顶点位置存在且顶点的标记不同,说明不在一个集合中,不会产生回路if (assists[initial] != assists[end]) {//记录该边,作为最小生成树的组成部分minTree[num] = edges[i];//计数+1num++;elem = assists[end];//将新加入生成树的顶点标记全部改为一样的for (k = 0; k < P; k++) {if (assists[k] == elem) {assists[k] = assists[initial];}}//如果选择的边的数量和顶点数相差1,证明最小生成树已经形成,退出循环if (num == P - 1) {break;}}}
}void display(struct edge minTree[]) {int cost = 0, i;printf("最小生成树为:\n");for (i = 0; i < P - 1; i++) {printf("%d-%d  权值:%d\n", minTree[i].initial, minTree[i].end, minTree[i].weight);cost += minTree[i].weight;}printf("总权值为:%d", cost);
}int main() {int i;struct edge edges[N], minTree[P - 1];for (i = 0; i < N; i++) {scanf("%d %d %d", &edges[i].initial, &edges[i].end, &edges[i].weight);}kruskal_MinTree(edges, minTree);display(minTree);return 0;
}

相关内容

热门资讯

网购冲锋衣货不对板 消保委调解... 本报上海讯(记者刘浩)消费者汪先生网购冲锋衣遭遇货不对板问题,向商家提出退货退款并赔偿的要求,遭商家...
原创 中... 在现代国际舞台上,地缘政治的博弈和历史遗产的保护之间的冲突并不罕见。然而,就在刚刚过去的周末,巴拿马...
民警搬“新法”调解邻里纠纷 专... 央广网亳州12月30日消息(记者刘浩)近日,安徽省亳州市涡阳县公安局星园派出所巧用新修订的《中华人民...
全球主要央行货币政策转向宽松 当地时间12月10日,美联储宣布年内第三次降息。 自9月开始,美联储连续3次下调基准利率,累计降息7...
新能泰山:公司已制定并披露《市... 证券之星消息,新能泰山(000720)12月29日在投资者关系平台上答复投资者关心的问题。 投资者提...
宁夏数据条例2026年1月1日... 记者12月29日从自治区发展改革委获悉,宁夏数据领域首部地方性法规——《宁夏回族自治区数据条例》(以...
《贵州法治报·理论研究》丨发挥... 2022年12月,习近平总书记就非遗保护工作作出重要指示,着重强调要扎实做好非遗的系统性保护,以更好...
法律援助为未成年人要回抚养费 □河南法治报记者 董景娅 尤某与宋某于2003年10月登记结婚,2016年5月两人共同收养了刚出生的...
中共中央统战部召开党外人士形势... 12月29日,党外人士形势和政策报告会在京召开,专题传达学习贯彻中央经济工作会议精神。国家发展改革委...
银川原副市长郭柏春案开庭,曾因... 2025年12月29日,宁夏回族自治区银川市原副市长郭柏春涉嫌挪用公款、滥用职权一案在银川市中级人民...