首页 > 编程语言 >858 Prim算法求最小生成树

858 Prim算法求最小生成树

时间:2022-10-24 23:35:42浏览次数:54  
标签:Prim int 858 最小 算法 集合 dist INF

#include<bits/stdc++.h>
using namespace std;

const int N = 510, INF = 0x3f3f3f3f;
int n, m;
int g[N][N];  //储存边
int dist[N];  //储存点到集合的距离
int st[N];    //判断点是否已经加入集合

int Prim() {
    int res = 0;
    for (int i = 0; i < n; i++) {      //n个节点遍历n次
        int t = -1;
        for (int j = 1; j <= n; j++){
            if (!st[j] && (t == -1 || dist[t] > dist[j])) t = j;   //某个节点没有被加入集合 并且是未被加入集合中的距离离集合最小的
        }
            if (i && dist[t] == INF) return INF;                   //  如果某个点距离集合距离为INF就不能生成最小生成树
            if (i) res += dist[t];                                  //  加入一条边到集合中就加上他的权重
            
            for (int j = 1; j <= n; j++) {                          //
                if (!st[j]) dist[j] = min(dist[j], g[t][j]);        //用这个点更新其他点的距离
            }
            st[t] = true;                                             
        }
    
    return res;
}

int main() {
    cin >> n >> m;
    
    memset(dist, 0x3f, sizeof dist);
    memset(g, 0x3f, sizeof g);
    for (int i = 0; i < m; i++) {
        int a, b, w;
        cin >> a >> b >> w;
        g[a][b] = g[b][a] = min(g[a][b], w);
    }
    
    int t = Prim();
    if (t == INF) puts("impossible");
    else cout << t;
    return 0;
}

标签:Prim,int,858,最小,算法,集合,dist,INF
From: https://www.cnblogs.com/echoT/p/16823464.html

相关文章

  • 全排列算法的一种
    链接:https://ac.nowcoder.com/acm/problem/16661来源:牛客网题目描述人类终于登上了火星的土地并且见到了神秘的火星人。人类和火星人都无法理......
  • 贪心算法-455分发饼干
    题目455分发饼干假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。对每个孩子i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干......
  • HotSpot的算法实现
    枚举根节点由于目前的主流Java虚拟机使用的都是准确式GC,当执行系统停顿下来后,并不需要一个不漏地检查完所有执行上下文和全局的引用位置,虚拟机应当是有办法直接得知哪些地......
  • 垃圾收集算法
    标记-清除算法Mark-Sweep首先标记出所有需要回收的对象,在标记完成后统一回收所有被标记的对象。由两个不足:效率问题标记和清除两个过程的效率都不高空间问题标记清除之后......
  • ST算法
    ST算法ST算法可以在\(O(N\logN)\)时间的预处理后,以\(O(1)\)的时间复杂度在线回答区间最值问题。状态转移一个序列的子区间个数显然有\(N^2\)个,根据倍增思想,我们......
  • C++算法之旅、01 入门篇
    使用胡凡主编的《算法笔记》教材。题目均为第三章题目。TEST//ProblemAddress#define_CRT_SECURE_NO_WARNINGS#include<cstdio>intmain(){return0;}PAT......
  • 第4章 最基础的分类算法-k近邻算法 kNN
    4-1k近邻算法基础 ......
  • cv算法(cv算法题笔试题库)
    CV值怎样计算阀门的流量不仅跟阀门的Cv值有关系,还跟压差有关系,Kv值的定义是阀门压差在100Kpa的情况下,通过阀门的流量(m3/h)Cv=1.167Kvex=(0.8+1+1.1+0.7+1.2)/5=0.96cv=s......
  • 力扣 114. 二叉树展开为链表-原地算法(O(1) 额外空间)详解
    114.二叉树展开为链表给你二叉树的根结点 root ,请你将它展开为一个单链表:展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而......
  • BZOJ 4519([Cqoi2016]不同的最小割-Gusfield算法)
    题意:给一幅图,问2点之间最小割有几个不同取值。1<=N<=8501<=M<=8500Gusfield算法如下:假设一开始所有点均在同一集合任意选定2个不在同一集合点求最小割,割把点集分成......