0

0

c++中如何实现Kruskal算法_c++ Kruskal算法实现方法

冰火之心

冰火之心

发布时间:2025-09-26 19:12:02

|

800人浏览过

|

来源于php中文网

原创

Kruskal算法通过排序边和并查集检测环,逐步选择最小权重边构建最小生成树。首先定义边结构体并按权重排序,使用并查集判断顶点连通性,避免成环。初始化每个顶点的父节点为自身,遍历排序后的边,若两端点不在同一集合,则加入生成树并合并集合。最终得到包含所有顶点的无环连通子图。该方法时间复杂度为O(E log E),适用于稀疏图。示例中5个顶点6条边,经排序与并查集处理后输出最小生成树各边及其权重。核心在于贪心策略与高效连通性检查的结合。

c++中如何实现kruskal算法_c++ kruskal算法实现方法

Kruskal算法用于求解无向图的最小生成树(MST),核心思想是按边的权重从小到大排序,依次选择边并避免形成环,直到生成树包含所有顶点。在C++中,通常结合并查集(Union-Find)来高效判断是否成环。

1. 数据结构设计

需要定义边的结构体,并实现并查集来管理顶点的连通性。

struct Edge {

  int u, v, weight;

立即学习C++免费学习笔记(深入)”;

  Edge(int u, int v, int w) : u(u), v(v), weight(w) {}

};

使用vector存储所有边,并按权重排序:

bool cmp(Edge a, Edge b) {

  return a.weight

}

2. 并查集实现

并查集用于快速查找根节点和合并集合,防止加入边后形成环。

int find(vector& parent, int x) {

  if (parent[x] != x)

    parent[x] = find(parent, parent[x]); // 路径压缩

  return parent[x];

}

void unite(vector& parent, vector& rank, int x, int y) {

  int rootX = find(parent, x);

  int rootY = find(parent, y);

  if (rootX != rootY) {

    if (rank[rootX]

      parent[rootX] = rootY;

    else if (rank[rootX] > rank[rootY])

      parent[rootY] = rootX;

    else {

      parent[rootY] = rootX;

      rank[rootX]++;

    }

  }

}

3. Kruskal主函数

将所有边排序后逐个尝试加入生成树,使用并查集检查连接性。

vector kruskal(int n, vector& edges) {

  vector result;

MD5校验和计算小程序(C)
MD5校验和计算小程序(C)

C编写,实现字符串摘要、文件摘要两个功能。里面主要包含3个文件: Md5.cpp、Md5.h、Main.cpp。其中Md5.cpp是算法的代码,里的代码大多是从 rfc-1321 里copy过来的;Main.cpp是主程序。

下载

  sort(edges.begin(), edges.end(), cmp);

  vector parent(n);

  vector rank(n, 0);

  // 初始化并查集

  for (int i = 0; i

    parent[i] = i;

  for (Edge& e : edges) {

    int u = e.u, v = e.v;

    if (find(parent, u) != find(parent, v)) { // 不连通

      result.push_back(e);

      unite(parent, rank, u, v); // 合并集合

    }

  }

  return result;

}

4. 使用示例

假设有5个顶点和6条边:

int main() {

  int n = 5;

  vector edges;

  edges.push_back(Edge(0, 1, 2));

  edges.push_back(Edge(0, 3, 6));

  edges.push_back(Edge(1, 2, 3));

  edges.push_back(Edge(1, 3, 8));

  edges.push_back(Edge(1, 4, 5));

  edges.push_back(Edge(2, 4, 7));

  vector mst = kruskal(n, edges);

  cout

  for (Edge& e : mst) {

    cout

  }

  return 0;

}

基本上就这些。关键在于边排序和并查集的配合使用,确保每次选的都是当前最短且不会成环的边。时间复杂度主要由排序决定,为 O(E log E),适合稀疏图。

相关专题

更多
edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1308

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

376

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

880

2025.04.24

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

737

2023.08.22

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

385

2023.09.04

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

195

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

187

2025.07.04

c语言union的用法
c语言union的用法

c语言union的用法是一种特殊的数据类型,它允许在相同的内存位置存储不同的数据类型,union的使用可以帮助我们节省内存空间,并且可以方便地在不同的数据类型之间进行转换。使用union时需要注意对应的成员是有效的,并且只能同时访问一个成员。本专题为大家提供union相关的文章、下载、课程内容,供大家免费下载体验。

122

2023.09.27

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.7万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 12.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号