链式并查集合并(裸板)
对于操作:将一段元素合并为同类。
在合并
这一段数的时候,其实有很多数本来就在一个并查集里。我们只需要合并若干个还没有合并的并查集,而不需要从 到 一个一个合并。因为只要合并了这几个并查集,效果等价于把 直接合并了。
实现方法:每次记录一个
https://codeforces.com/problemset/problem/566/D
#include<bits/stdc++.h>
#define endl '\n'
#define lowbit(x) (x&-x)
using namespace std;
const double pi=acos(-1);
const int N=2e5+5;
int fa[N],nx[N];
int find(int i){
if(i!=fa[i]) fa[i]=find(fa[i]);//路径压缩
return fa[i];
}
void join(int u,int v){
u=find(u);
v=find(v);
if(u==v) return;
if(u<v) swap(u,v);
fa[v]=u;
}
void solve(){
int n,q;cin>>n>>q;
for(int i=1;i<=n+1;i++){
fa[i]=i;
nx[i]=i+1;
}
while(q--){
int op;cin>>op;
int x,y;cin>>x>>y;
if(op==3){
x=find(x);
y=find(y);
if(x==y) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
if(op==1){
join(x,y);
}
if(op==2){
int ty=find(y);
for(int i=x;i<=y;){
int t=i;
i=nx[i];
fa[find(t)]=ty;
nx[t]=nx[y];
}
}
}
}
signed main(){
ios::sync_with_stdio(false);cin.tie(nullptr);
int t=1;
//cin>>t;
while(t--) solve();
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】