0

0

c++中如何实现Kruskal最小生成树_c++ Kruskal最小生成树实现方法

冰火之心

冰火之心

发布时间:2025-09-27 15:04:01

|

351人浏览过

|

来源于php中文网

原创

Kruskal算法通过排序和并查集求最小生成树,先按权重排序边,再遍历选边并用并查集避免环,直到选出n-1条边。

c++中如何实现kruskal最小生成树_c++ kruskal最小生成树实现方法

Kruskal算法用于求解无向连通图的最小生成树,核心思想是按边的权重从小到大排序,依次选择边并确保不形成环,直到选够n-1条边(n为顶点数)。在C++中实现Kruskal算法,主要涉及边的排序和使用并查集(Union-Find)来检测环。

定义边结构与并查集

每条边包含起点、终点和权重。用结构体表示边,并重载比较函数以便排序。

struct Edge {
    int u, v, weight;
    bool operator<(const Edge& other) const {
        return weight < other.weight;
    }
};

并查集用于高效判断两个顶点是否在同一连通分量中,避免成环。

class UnionFind {
    vector parent;
public:
    UnionFind(int n) {
        parent.resize(n);
        for (int i = 0; i < n; ++i) parent[i] = i;
    }
int find(int x) {
    if (parent[x] != x)
        parent[x] = find(parent[x]);
    return parent[x];
}

void unite(int x, int y) {
    parent[find(x)] = find(y);
}

bool connected(int x, int y) {
    return find(x) == find(y);
}

};

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

实现Kruskal主函数

将所有边存入容器,排序后逐个尝试加入生成树。使用并查集判断是否会产生环。

AI发型设计
AI发型设计

虚拟发型试穿工具和发型模拟器

下载
vector kruskal(vector& edges, int n) {
    sort(edges.begin(), edges.end());
    UnionFind uf(n);
    vector result;
for (const auto& e : edges) {
    if (!uf.connected(e.u, e.v)) {
        uf.unite(e.u, e.v);
        result.push_back(e);
        if (result.size() == n - 1) break;
    }
}
return result;

}

完整调用示例

假设图有4个节点,边如下:

int main() {
    vector edges = {
        {0, 1, 10}, {0, 2, 6}, {0, 3, 5},
        {1, 3, 15}, {2, 3, 4}
    };
    int n = 4;
    vector mst = kruskal(edges, n);
cout zuojiankuohaophpcnzuojiankuohaophpcn "最小生成树的边:\n";
for (const auto& e : mst) {
    cout zuojiankuohaophpcnzuojiankuohaophpcn e.u zuojiankuohaophpcnzuojiankuohaophpcn " -- " zuojiankuohaophpcnzuojiankuohaophpcn e.v zuojiankuohaophpcnzuojiankuohaophpcn " : " zuojiankuohaophpcnzuojiankuohaophpcn e.weight zuojiankuohaophpcnzuojiankuohaophpcn "\n";
}
return 0;

}

输出结果会显示构成最小生成树的边及其权重,总权重最小且无环。

基本上就这些。排序+并查集是Kruskal的关键,代码清晰且易于理解。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

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

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

194

2025.06.09

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

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

187

2025.07.04

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

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

122

2023.09.27

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

399

2023.08.14

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

10

2026.01.12

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

106

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

64

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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