题解 | 畅通工程 并查集

畅通工程

https://www.nowcoder.com/practice/4878e6c6a24e443aac5211d194cf3913

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
using namespace std;

// 全局变量
int father[1001];
int setCount = 0;  // 统计并查集(相互不连通)的数量

// 初始化
void InitDisjoinSet(int n) {
    for (int i = 1; i <= n; i++) {
        father[i] = i;
    }
}

// 找根结点
int FindDisjoinSet(int u) {
    if (u == father[u]) {
        return u;
    } else {
        // 压缩路径
        father[u] = FindDisjoinSet(father[u]);
        return father[u];
    }
}

// 合并并查集
void UnionDisjoinSet(int u, int v) {
    int uroot = FindDisjoinSet(u);
    int vroot = FindDisjoinSet(v);
    if (uroot != vroot) {  // u v在不同集合里,将要合并,大集合数量减一
        setCount--;
    }
    father[vroot] = uroot;  //  v 挂载载 u 上
}

int main() {
    int m, n;
    while (scanf("%d", &n) != EOF) {
        if (n == 0) {
            break;
        }
        scanf("%d", &m);
        InitDisjoinSet(n);  // 初始化1-n个结点
        setCount = n;  // 刚开始,所有集合都独立

        for (int i = 0; i < m; i++) {
            int u, v;
            scanf("%d %d", &u, &v);
            UnionDisjoinSet(u, v);
        }
        printf("%d\n", setCount - 1);
    }
    return 0;
}

#考研##复试练习#
2025考研复试 文章被收录于专栏

复试ing,努力中。。。

全部评论

相关推荐

淬月星辉:专利是什么?至少描述一下吧,然后把什么计算机二级、普通话这种拉低格调的证书删掉,不然hr以为你没东西写
点赞 评论 收藏
分享
11-04 19:05
已编辑
东莞城市学院 单片机
不知道怎么取名字_:你这个要实习两年?哪有这么久的,感觉就是即使你毕业了,但还按实习的话,是不是不用给你缴社保公积金啥的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务