局域网——Prim Kruskal

题目

Prim (生成一颗包含起点的最小生成树,所以要多次调用)

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

const int N = 510;
const int inf = 0x3f3f3f3f;

int n, m;
int g[N][N], dis[N];
bool p[N], vis[N];

int prim (int u)
{
    memset(dis, 0x3f, sizeof dis); dis[u] = 0;
    int sum = 0;
    for(int i = 0 ; i < n ; i ++ )
    {
        int t = -1;
        for(int j = 1 ; j <= n ; j ++ )
            if(!p[j] && (t == -1 || dis[t] > dis[j]))
                t = j;
        if(i && dis[t] == inf) return sum;
        p[t] = 1;
        if(i) sum += dis[t]; // 第一个点为根节点没有边权
        vis[t] = 1;
        for(int j = 1 ; j <= n ; j ++ )
            if(!p[j] && dis[j] > g[t][j]) dis[j] = g[t][j];
    }
    return sum;
}

int main ()
{
    int ans = 0;
    cin >> n >> m;
    for(int i = 1 ; i <= n ; i ++ )
        for(int j = 1 ; j <= n ; j ++ )
            if(i == j) g[i][j] = 0;
            else g[i][j] = inf;
    for(int i = 1 ; i <= m ; i ++ )
    {
        int a, b, c;
        cin >> a >> b >> c;
        g[a][b] = g[b][a] = min(g[a][b], c);
        ans += min(g[a][b], c);
    }
    int t = 0;
    for(int i = 1 ; i <= n ; i ++ )
        if(!vis[i]) t += prim(i);
    cout << ans - t << endl;
    return 0;
}

Kruskal (如果有多颗生成树,生成最小生成森林)

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 110;
const int M = 210;
struct edge{
    int a;
    int b;
    int c;
    
    bool operator < (const edge& v)
    {
        return c < v.c;
    }
} e[M];
int p[N];
int n, idx, m;
int find(int x)
{
    if(p[x] != x) p[x] = find(p[x]);
    return p[x];
}
int kruskal()
{
    int retv = 0;
    
    for(int i = 1; i <= n; i++)
        p[i] = i;
    sort(e+1,e+m+1);
    
    for(int i = 1; i <= m; i++)
    {
        int a = e[i].a, b = e[i].b, c = e[i].c;
        a = find(a), b = find(b);
        if(a != b)
        {
            p[a] = b;
            retv += c;
        }
    }
    
    return retv;
}
int main()
{
    cin >> n >> m;
    int sum = 0;
    for(int i = 1; i <= m; i++)
    {
        int a, b, c;
        cin >> a >> b >> c;
        e[++idx]  = {a, b, c};
        sum += c;
    }
            
    int t = kruskal();
    cout << sum - t;
}
相关推荐
↣life♚23 分钟前
从SAM看交互式分割与可提示分割的区别与联系:Interactive Segmentation & Promptable Segmentation
人工智能·深度学习·算法·sam·分割·交互式分割
zqh1767364646929 分钟前
2025年阿里云ACP人工智能高级工程师认证模拟试题(附答案解析)
人工智能·算法·阿里云·人工智能工程师·阿里云acp·阿里云认证·acp人工智能
fie88891 小时前
用模型预测控制算法实现对电机位置控制仿真
算法
Kent_J_Truman1 小时前
【交互 / 差分约束】
算法
ghie90901 小时前
x-IMU matlab zupt惯性室内定位算法
人工智能·算法·matlab
Magnum Lehar1 小时前
3d游戏引擎的Utilities模块实现
c++·算法·游戏引擎
yzx9910133 小时前
支持向量机的回归用法详解
算法·支持向量机·回归
小羊在奋斗3 小时前
【LeetCode 热题 100】反转链表 / 回文链表 / 有序链表转换二叉搜索树 / LRU 缓存
算法·leetcode·链表
爱上彩虹c3 小时前
LeetCode Hot100 (1/100)
算法·leetcode·职场和发展
小陈的进阶之路3 小时前
计算机大类专业数据结构下半期实验练习题
数据结构·算法·深度优先