题解 | 畅通工程 并查集

畅通工程

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,努力中。。。

全部评论

相关推荐

09-13 17:25
亲切的00后在笔试:我也遇到了,所以我早他一步查看图片
点赞 评论 收藏
分享
10-21 00:37
已编辑
门头沟学院 C++
小浪_Coding:你问别人,本来就是有求于人,别人肯定没有义务免费回答你丫, 有点流量每天私信可能都十几,几十条的,大家都有工作和自己的事情, 付费也是正常的, 就像你请别人搭把手, 总得给人家买瓶水喝吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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