Kruskal

简介: 复习acwing算法基础课的内容,本篇为讲解基础算法:Kruskal,关于时间复杂度:目前博主不太会计算,先鸽了,日后一定补上。

文章目录

前言

一、Kruskal算法

二、AcWing 859. Kruskal算法求最小生成树

本题分析

AC代码

三、时间复杂度


前言

复习acwing算法基础课的内容,本篇为讲解基础算法:Kruskal,关于时间复杂度:目前博主不太会计算,先鸽了,日后一定补上。


一、Kruskal算法

把所有边按照权重从小到大进行排序,枚举每条边(a,b,w),如果a,b不连通,把这条边也加入到集合中,判断a,b是否联通用的是并查集


下图来自AcWing算法基础课:

image.png

二、AcWing 859. Kruskal算法求最小生成树

本题链接:AcWing 859. Kruskal算法求最小生成树

本博客提供本题截图:

image.png

本题分析

p数组就是并查集中的p数组,find函数就是并查集中的find函数,res存储的是最小生成树中的所有树边的权重之和,cnt存储的是当前加入了多少条边,因为一共有n个点,所以如果最后的边数小于n - 1的话,证明不存在最小生成树

AC代码

#include <cstdio>
#include <algorithm>
using namespace std;
const int N = 100010, M = 200010;
const int INF = 0x3f3f3f3f;
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()
{
    sort(edges, edges + m);
    for (int i = 1; i <= n; i ++ ) p[i] = i;
    int res = 0, cnt = 0;
    for (int i = 0; i < m; i ++ )
    {
        auto t = edges[i];
        int a = t.a, b = t.b, w = t.w;
        a = find(a), b = find(b);
        if (a != b)
        {
            res += w;
            cnt ++;
            p[a] = b;
        }
    }
    if (cnt < n - 1) return INF;
    else return res;
}
int main()
{
    scanf("%d%d", &n, &m);
    for (int i = 0; i < m; i ++ )
    {
        int a, b, w;
        scanf("%d%d%d", &a, &b, &w);
        edges[i] = {a, b, w};
    }
    int t = kruskal();
    if (t == INF) printf("impossible");
    else printf("%d", t);
    return 0;
}

三、时间复杂度

关于Kruskal算法的时间复杂度以及证明,后续会给出详细的说明以及证明过程,目前先鸽了。


目录
相关文章
|
算法
最小生成树算法:Prim算法
在图论中,最小生成树(Minimum Spanning Tree,简称MST)是一种常用的算法问题。最小生成树是指在一个加权连通图中选取边的子集,使得所有顶点都被覆盖,并且边的总权值最小。
315 0
|
算法
SPFA算法-最短路-负环
SPFA算法-最短路-负环
93 0
|
8月前
|
存储 算法
最短路之SPFA算法
最短路之SPFA算法
62 0
|
算法 搜索推荐
Kruskal算法
Kruskal算法
115 0
|
算法 C++
用prim和kruskal算法求最小生成树问题
用prim和kruskal算法求最小生成树问题
89 0
|
机器学习/深度学习 算法 程序员
【算法合集】深搜广搜Prim与Kruskal
广度优先搜索(BFS)又叫广搜,它像一个有远见的人,它是一层一层来实现搜索的,也挺像下楼梯的。 思路: 1.先初始化队列 q; 2.从起点开始访问,并且改变他的状态为已经访问; 3.如果他的队列非空,取出首个元素,将它弹出! 4.如果u == 目标状态,然后对所以与 u 邻近的点进入队列; 5.标记它已经被访问!...............
187 1
|
算法 调度
最小生成树(Prim、Kruskal)算法,秒懂!
在数据结构与算法的图论中,(生成)最小生成树算法是一种常用并且和生活贴切比较近的一种算法。但是可能很多人对概念不是很清楚,什么是最小生成树?
207 0
最小生成树(Prim、Kruskal)算法,秒懂!
|
算法
图论最短路及生成树(Prim,Djikstra,Spfa,Bellan-ford,kruskal,topsort)
图论最短路及生成树(Prim,Djikstra,Spfa,Bellan-ford,kruskal,topsort)
144 1