搜索与图论——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;
}
相关推荐
吃好睡好便好1 天前
提取矩阵某一行或某一列元素
开发语言·人工智能·线性代数·算法·matlab·矩阵
云泽8081 天前
笔试算法 -位运算篇(二):从唯一字符到消失数字
c++·算法·位运算
ʚ希希ɞ ྀ1 天前
不同路径|| -- dp
算法
IT 行者1 天前
SimHash 与 MinHash:相似性计算的双子星算法
算法·hash·比对
智者知已应修善业1 天前
【51单片机8位数码管动态显示日期小数点风格】2023-11-13
c++·经验分享·笔记·算法·51单片机
智者知已应修善业1 天前
【51单片机有三个LED 分别第一个灯闪三下 再到第二个灯又闪三下 再到第三个灯又闪三下 就这样循环程序】2023-11-16
c++·经验分享·笔记·算法·51单片机
小L~~~1 天前
基于贪心策略的混合遗传算法求解01背包问题
python·算法
洛水水1 天前
【力扣100题】53.最长回文子串
算法·leetcode·职场和发展
jieyucx1 天前
Go 语言 sort 包详解:从基础排序到自定义排序(含底层原理+零基础看懂)
算法·golang·排序算法·sort