搜索与图论——Kruskal算法求最小生成树

kruskal算法相比prim算法思路简单,不用处理边界问题,不用堆优化,所以一般稀疏图都用Kruskal。

Kruskal算法时间复杂度O(mlogm)

每条边存结构体里,排序需要在结构体里重载小于号

判断a,b点是否连通以及将点假如集合中需要并查集的知识

cpp 复制代码
#include<iostream>
#include<cstring>
#include<algorithm>

using namespace std;

const int N = 100010, M = 200010;

int n, m;
int p[N];

struct Edge
{
    int a, b, w;
    bool operator< (const Edge& W)const
    {
        return w < W.w;
    }
}edges[M];

int find(int x)
{
    if(p[x] != x) p[x] = find(p[x]);
    return p[x];
}

int Kruskal()
{
    int res = 0,cnt = 0;
    for(int i = 1; i <= n; i ++ )
    {
        p[i] = i;
    }
    for(int i = 0; i < m; i ++ )
    {
        int a = find(edges[i].a), b = find(edges[i].b);
        if(a != b)
        {
            p[a] = b;
            res += edges[i].w;
            cnt ++ ;
        }
    }
    if(cnt < n - 1) return 0;
    else return res;
}

int main()
{
    cin >> n >> m;
    for(int i = 0; i < m; i ++ )
    {
        int a, b, w;
        cin >> a >> b >> w;
        edges[i].a = a, edges[i].b = b, edges[i].w = w;
    }
    sort(edges, edges + m);
    int t = Kruskal();
    if(!t) cout << "impossible" << endl;
    else cout << t << endl;
    return 0;
}
相关推荐
夜思红尘16 小时前
算法--双指针
python·算法·剪枝
散峰而望16 小时前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
点云SLAM16 小时前
BOOS库中Graph模块boost::edge_reverse_t和boost::vertex_color_t解读
数据库·edge·图论·bfs·dfs/拓扑排序·boost库、
CoderCodingNo16 小时前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
我有一些感想……16 小时前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
前端小L16 小时前
双指针专题(三):去重的艺术——「三数之和」
javascript·算法·双指针与滑动窗口
智者知已应修善业17 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
LYFlied18 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
多米Domi01118 小时前
0x3f 第19天 javase黑马81-87 ,三更1-23 hot100子串
python·算法·leetcode·散列表
历程里程碑18 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode