题解 | 畅通工程 并查集

畅通工程

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

全部评论

相关推荐

半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
05-26 22:25
门头沟学院 Java
Java小肖:不会是想叫你过去把你打一顿吧,哈哈哈
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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