洛谷 P3367 【模板】并查集

题目背景

本题数据范围已经更新到 1≤N≤2×105,1≤M≤106。

题目描述

如题,现在有一个并查集,你需要完成合并和查询操作。

输入格式

第一行包含两个整数 N,M ,表示共有 N 个元素和 M 个操作。

接下来 M 行,每行包含三个整数 Zi​,Xi​,Yi​ 。

当 Zi​=1 时,将 Xi​ 与 Yi​ 所在的集合合并。

当 Zi​=2 时,输出 Xi​ 与 Yi​ 是否在同一集合内,是的输出 Y ;否则输出 N

输出格式

对于每一个 Zi​=2 的操作,都有一行输出,每行包含一个大写字母,为 Y 或者 N

输入输出样例

输入 #1复制

复制代码
4 7
2 1 2
1 1 2
2 1 2
1 3 4
2 1 4
1 2 3
2 1 4

输出 #1复制

复制代码
N
Y
N
Y

说明/提示

对于 15% 的数据,N≤10,M≤20。

对于 35% 的数据,N≤100,M≤103。

对于 50% 的数据,1≤N≤104,1≤M≤2×105。

对于 100% 的数据,1≤N≤2×105,1≤M≤106,1≤Xi​,Yi​≤N,Zi​∈{1,2}。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
int fa[N];
int find(int x)
{
    if(fa[x]==x)
    return x;
    else
    return fa[x]=find(fa[x]);
}
int main()
{
    int n,m;
    cin>>n>>m;
    for(int i=1;i<=n;i++)
    fa[i]=i;
    while(m--)
    {
        int z,x,y;
        cin>>z>>x>>y;
        if(z==1)
        {
            int fx=find(x);
            int fy=find(y);
            fa[fx]=fy;
        }else{
            if(find(x)==find(y))
            cout<<"Y"<<endl;
            else
            cout<<"N"<<endl;
        }
    }
    return 0;
}
相关推荐
naruto_lnq2 小时前
C++中的桥接模式
开发语言·c++·算法
苦藤新鸡2 小时前
50.腐烂的橘子
数据结构·算法
想进个大厂2 小时前
代码随想录day32 动态规划01
算法·动态规划
j445566112 小时前
C++中的职责链模式高级应用
开发语言·c++·算法
uesowys2 小时前
Apache Spark算法开发指导-Decision tree classifier
算法·决策树·spark
池央3 小时前
贪心算法-最大数
算法·贪心算法
iAkuya3 小时前
(leetcode)力扣100 57电话号码的字母组合(回溯)
算法·leetcode·深度优先
m0_736919103 小时前
模板元编程性能分析
开发语言·c++·算法
pen-ai3 小时前
【YOLO系列】 YOLOv1 目标检测算法原理详解
算法·yolo·目标检测
2301_765703143 小时前
C++中的职责链模式实战
开发语言·c++·算法