当前位置:首页 > 洛谷 > 洛谷1111题解题全解析:基于Kruskal算法与并查集的最小生成树实现

洛谷1111题解题全解析:基于Kruskal算法与并查集的最小生成树实现

13小时前

洛谷1111题解题全解析:基于Kruskal算法与并查集的最小生成树实现 洛谷1111题解析 Kruskal算法 最小生成树 并查集 图论算法 代码注释 解题思路 复杂度优化 稀疏图处理 C++实现 第1张


一、题目解读

洛谷1111题是一道经典的图论问题,要求构建一个无向图最小生成树,并输出其最大边权值。题目核心在于通过给定的边集合,找到连接所有节点的最小权值子集,同时保证无环。这通常涉及最小生成树算法(如Kruskal)的应用,需要高效处理边权重与节点连通性。

二、解题思路

用户提供的代码采用Kruskal算法并查集的结合,巧妙解决最小生成树问题。其核心思路为:

    1. 贪心策略:按边权重递增排序,优先选择权值最小的边;

    2. 连通性判断:利用并查集快速合并节点,避免形成环。

通过这两个关键步骤,算法能在O(ElogE)复杂度下高效求解。

三、解题步骤

1. 输入与初始化:

    读取节点数N和边数M,创建边集合edges;

    初始化并查集parent数组(每个节点初始为自身根节点)。

2. 边排序:对edges按权值t升序排序,确保后续按权重递增处理。

3. 核心循环:遍历每条边,执行合并操作:

    通过find函数获取边两端节点的真实根节点;

    若根节点不同,合并节点并更新最大边权值max_t。

4. 结果判断:若合并次数达到N-1(即形成一棵树),输出max_t;否则输出-1(不连通)。

四、代码与注释

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;

// 边结构(节点u、v及权值t)
struct Edge {
    int u, v, t;
    bool operator<(const Edge& other) const {
        return t < other.t; // 按权值排序比较函数
    }
};

vector<int> parent; // 并查集:记录节点的根节点

// 查找节点x的根节点(路径压缩优化)
int find(int x) {
    return parent[x] == x? x : parent[x] = find(parent[x]);
}

// 合并节点x与y,返回是否成功(避免环)
bool unite(int x, int y) {
    x = find(x); // 获取x的根
    y = find(y); // 获取y的根
    if(x == y) return false; // 同根则不合并
    parent[y] = x; // 合并y到x
    return true;
}

int main() {
    int N, M;
    cin >> N >> M;
    vector<Edge> edges(M);
    parent.resize(N+1); // 初始化并查集数组
    
    // 初始化:每个节点为独立根节点
    for(int i=1; i<=N; i++) parent[i] = i;
    // 输入边信息
    for(int i=0; i<M; i++) 
        cin >> edges[i].u >> edges[i].v >> edges[i].t;
    
    // 按权值排序
    sort(edges.begin(), edges.end());
    
    int cnt = 0, max_t = 0; // 合并次数与最大边权
    for(auto& e : edges) {
        // 若合并成功且未形成完整树,更新信息
        if(unite(e.u, e.v)) {
            max_t = max(max_t, e.t);
            if(++cnt == N-1) break; // 树已生成,退出循环
        }
    }
    
    // 根据连通性输出结果
    cout << (cnt == N-1? max_t : -1) << endl;
    return 0;
}

五、总结

本解法通过Kruskal算法与并查集的深度融合,实现了高效的最小生成树构建。其优势在于:

1. 时间复杂度优化:排序+并查集降低处理复杂度;

2. 代码简洁性:结构清晰,逻辑易懂,适合竞赛与工程场景。

该思路为同类图论问题提供了通用解决方案,尤其在稀疏图环境中表现优异。


原创内容 转载请注明出处

分享给朋友:

相关文章

汉诺塔问题递归解法(C++代码详解) 牛客4414题解题指南

汉诺塔问题递归解法(C++代码详解) 牛客4414题解题指南

一、题目解读汉诺塔问题是一个经典的递归算法题目:有n个大小不同的圆盘按从大到小顺序放在柱A上,需借助柱B,将圆盘移至柱C,每次只能移动一个圆盘,且大圆盘不能置于小圆盘之上。牛客4414题要求编写函数输...

快速排序算法详解 C++代码实现

一、简介和特点快速排序(QuickSort)是一种经典的高效排序算法,采用分治思想:通过选定一个枢轴元素(pivot),将数组划分为左右两部分,使左侧元素均小于枢轴,右侧元素均大于枢轴,再递归对子数组...

洛谷2181题解析:组合数学中顶点交点的计算与代码优化

洛谷2181题解析:组合数学中顶点交点的计算与代码优化

一、题目解读洛谷2181题要求计算n个顶点中任意选择4个顶点确定的交点数量。题目核心在于组合数学的应用,需通过排列组合公式推导结果,同时注意处理大数以避免溢出问题。理解题目中的“交点”定义(由4个顶点...

手搓邻接矩阵类代码注释与实现指南:从零开始理解图论数据结构(适合小白)

一、简介和特点邻接矩阵是用于表示图(Graph)的一种数据结构,通常用二维数组存储节点之间的关系。本文的graph类通过C++实现了一个基础的邻接矩阵结构,特点如下:1. 动态创建:根据用户输入的节点...

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

2024蓝桥杯省赛B组“传送阵”题解(C++代码+图论算法优化)

一、题目解读2024年蓝桥杯省B组“传送阵”题目要求处理一个包含n个节点的图,节点间存在单向传输关系。每个节点i可传送至a[i]指定的节点,形成可能存在的环结构。题目需求解从任意节点出发能到达的最长路...

洛谷P4551题解题报告:图论与Trie树优化异或路径问题的实战解析

洛谷P4551题解题报告:图论与Trie树优化异或路径问题的实战解析

一、题目解读洛谷P4551题要求在一个无向图中,寻找任意两点路径权值异或后的最大值。题目输入为图的边信息(点数n和n-1条边),每条边包含起点、终点及权值。需输出所有路径中权值异或的最大值。问题核心在...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。