
标题:C++中Prim算法的使用及代码示例
引言:Prim算法是一种常用的最小生成树算法,主要用于解决图论中的最小生成树问题。在C++中,通过合理的数据结构和算法实现,可以有效地使用Prim算法。本文将介绍如何在C++中使用Prim算法,并提供具体的代码示例。
一、Prim算法简介
Prim算法是一种贪心算法,它从一个顶点开始,逐步扩展最小生成树的顶点集合,直到包含所有顶点。它通过不断选择与当前集合相连的最小权重的边来构建最小生成树。
二、Prim算法的实现步骤
立即学习“C++免费学习笔记(深入)”;
创建一个空的最小生成树集合和一个优先队列,用于存储边的权重和相连的顶点。随机选择一个顶点作为起始顶点,将其加入最小生成树集合。将与起始顶点相连的边加入优先队列。重复以下步骤直到最小生成树包含所有顶点:
a. 从优先队列中取出权重最小的边和相连的顶点。
b. 如果该顶点已经在最小生成树集合中,则忽略该边。
c. 否则,将该顶点加入最小生成树集合,并将与该顶点相连的边加入优先队列。输出最小生成树集合。
三、C++代码示例
下面是使用C++实现Prim算法的代码示例,其中使用了邻接矩阵表示图:
#include#include#include#includeusing namespace std;const int MAX = 100;const int INF = 9999;vector<vector> graph(MAX, vector(MAX, INF));void prim(int start, int n){ vector key(n, INF); // 存储每个顶点到最小生成树的最小权重 vector visited(n, false); // 标记顶点是否已经加入最小生成树 priority_queue<pair, vector<pair>, greater<pair>> pq; // 优先队列,按权重升序排列 key[start] = 0; // 起始顶点到自身的权重置为0 pq.push(make_pair(0, start)); while (!pq.empty()) { int u = pq.top().second; pq.pop(); visited[u] = true; for (int v = 0; v < n; v++) { if (graph[u][v] != INF && !visited[v] && graph[u][v] < key[v]) { key[v] = graph[u][v]; pq.push(make_pair(graph[u][v], v)); } } } // 输出最小生成树的边 for (int i = 1; i < n; i++) { cout << "Edge: " << i << " - " << key[i] << endl; }}int main(){ int n, e; cout <> n; cout <> e; cout << "Enter the edges and weights: " << endl; int u, v, w; for (int i = 0; i > u >> v >> w; graph[u][v] = w; graph[v][u] = w; } int start; cout <> start; cout << "Minimum Spanning Tree edges: " << endl; prim(start, n); return 0;}
四、总结
本文介绍了C++中如何使用Prim算法,并提供了一段具体的代码示例。通过使用合适的数据结构和算法实现,可以高效地计算最小生成树。希望本文对您在使用Prim算法解决最小生成树问题时有所帮助。
以上就是如何使用C++中的Prim算法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1445510.html
微信扫一扫
支付宝扫一扫