搜索与图论——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;
}
相关推荐
WolfGang00732126 分钟前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee2 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99902 小时前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5053 小时前
深入理解主成分分析(PCA)
算法
apollowing3 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app
晚枫歌F3 小时前
最小堆定时器
数据结构·算法
Lumos_7773 小时前
Linux -- 线程
java·jvm·算法
七颗糖很甜4 小时前
“十五五”气象发展规划:聚焦五大核心任务
大数据·python·算法
科研前沿4 小时前
镜像视界浙江科技有限公司的关键技术突破有哪些?
大数据·人工智能·科技·算法·音视频·空间计算
嫩萝卜头儿4 小时前
2 - 复杂度收尾 + 链表经典OJ
数据结构·算法·链表·复杂度