生成树是连接所有顶点的有向无向图子图。图中可以存在许多生成树。每个图上的最小生成树(mst)的权重相同或小于所有其他生成树。权重被分配给生成树的边,总和是分配给每个边的权重。由于 v 是图中的顶点数,因此最小生成树的边数为 (v – 1),其中 v 是边数。
使用 Kruskal 算法查找最小生成树
所有边应按权重非降序排列。
选择最小的边。如果未形成环,则包含该边。
应执行步骤 2,直到生成树具有 (V-1) 条边。
在这种情况下,我们被告知要使用贪婪方法。贪心选项是选择权重最小的边。举例来说:该图的最小生成树为 (9-1)= 8 条边。
立即学习“C++免费学习笔记(深入)”;

After sorting:Weight Src Dest21 27 2622 28 2222 26 2524 20 2124 22 2526 28 2627 22 2327 27 2828 20 2728 21 2229 23 2430 25 2431 21 2734 23 25
现在我们需要根据排序选取所有边。
包含边 26-27->,因为没有形成环
边包括 28-22->,因为没有形成环路
包括边缘 26-25->,因为没有形成环路。
包括边缘 20-21->,因为没有形成环路
边 22-25-> 被包含,因为没有形成环路。
边 28-26-> 因环路形成而被丢弃
边 22-23-> > 包括,因为没有形成环路
边 27-28-> 因环路形成而被丢弃
边线 20-27-> 包括,因为没有形成环路
边21-22->因形成环而被丢弃
边23-24->因未形成环而被包括
由于边的数量为(V-1),所以算法到此结束。
示例
#include #include #include struct Edge { int src, dest, weight;};struct Graph { int V, E; struct Edge* edge;};struct Graph* createGraph(int V, int E){ struct Graph* graph = (struct Graph*)(malloc(sizeof(struct Graph))); graph->V = V; graph->E = E; graph->edge = (struct Edge*)malloc(sizeof( struct Edge)*E); return graph;}struct subset { int parent; int rank;};int find(struct subset subsets[], int i){ if (subsets[i].parent != i) subsets[i].parent = find(subsets, subsets[i].parent); return subsets[i].parent;}void Union(struct subset subsets[], int x, int y){ int xroot = find(subsets, x); int yroot = find(subsets, y); if (subsets[xroot].rank subsets[yroot].rank) subsets[yroot].parent = xroot; else{ subsets[yroot].parent = xroot; subsets[xroot].rank++; }}int myComp(const void* a, const void* b){ struct Edge* a1 = (struct Edge*)a; struct Edge* b1 = (struct Edge*)b; return a1->weight > b1->weight;}void KruskalMST(struct Graph* graph){ int V = graph->V; struct Edge result[V]; int e = 0; int i = 0; qsort(graph->edge, graph->E, sizeof(graph->edge[0]), myComp); struct subset* subsets = (struct subset*)malloc(V * sizeof(struct subset)); for (int v = 0; v < V; ++v) { subsets[v].parent = v; subsets[v].rank = 0; } while (e < V - 1 && i E) { struct Edge next_edge = graph->edge[i++]; int x = find(subsets, next_edge.src); int y = find(subsets, next_edge.dest); if (x != y) { result[e++] = next_edge; Union(subsets, x, y); } } printf("Following are the edges in the constructed MSTn"); int minimumCost = 0; for (i = 0; i edge[0].src = 20; graph->edge[0].dest = 21; graph->edge[0].weight = 30; graph->edge[1].src = 20; graph->edge[1].dest = 22; graph->edge[1].weight = 26; graph->edge[2].src = 20; graph->edge[2].dest = 23; graph->edge[2].weight = 25; graph->edge[3].src = 21; graph->edge[3].dest = 23; graph->edge[3].weight = 35; graph->edge[4].src = 22; graph->edge[4].dest = 23; graph->edge[4].weight = 24; KruskalMST(graph); return 0;}
输出
Following are the edges in the constructed MST22 -- 23 == 2420 -- 23 == 2520 -- 21 == 30Minimum Cost Spanning tree : 79
结论
本教程演示了如何使用 Kruskal 的最小生成树算法-贪心法和 C++ 代码来解决此问题。我们还可以用java、python和其他语言编写这段代码。它是根据克鲁斯卡尔的概念建模的。该程序查找给定图中的最短生成树。我们希望本教程对您有所帮助。
以上就是Kruskal的最小生成树算法-贪婪算法在C++中的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1443945.html
微信扫一扫
支付宝扫一扫