首页 > 其他 > 详细

并查集

时间:2020-03-26 15:43:27      阅读:55      评论:0      收藏:0      [点我收藏+]
#include<bits/stdc++.h>
#define ri register int
#define ll long long
#define fast ios::sync_with_stdio(0), cin.tie(0), cout.tie(0)
using namespace std;
const inline int read(){
    int k = 0, f = 1; char c = getchar();
    for(;!isdigit(c); c = getchar())
        if(c == -) f = -1;
    for(;isdigit(c); c = getchar())
        k = k * 10 + c - 0;
    return k * f;
}
int n, m, f[10005];
int find(int x){
    if(x == f[x]) return x;
    return f[x] = find(f[x]);//路径压缩 
}
int main(){
    n = read(), m = read();
    for(ri i = 1; i <= n; ++i)
        f[i] = i;
    for(ri i = 1; i <= m; ++i){
        ri z, x, y;
        z = read(), x = read(), y = read();
        int a = find(x), b = find(y);
        if(z == 1)
            f[a] = b;//合并 
        else{
            if(a == b)
                printf("Y\n");
            else
                printf("N\n");
        }
    }
    return 0;
}

 

并查集

原文:https://www.cnblogs.com/kojoker/p/12574458.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!