【pb_ds】【平衡树启发式合并】【并查集】bzoj2733 [HNOI2012]永无乡
2024-08-23 20:58:28
用并查集维护联通性。对每个联通块维护一个平衡树。合并时启发式合并。比较懒,用了pb_ds。
#include<cstdio>
#include<ext/pb_ds/assoc_container.hpp>
#include<ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_cxx;
using namespace __gnu_pbds;
tree<int,null_type,less<int>,rb_tree_tag,tree_order_statistics_node_update> T[];
tree<int,null_type,less<int>,rb_tree_tag,tree_order_statistics_node_update>::iterator it;
int num[],val[],fa[],rank[];
int n,m,q,x,y,f1,f2;
char op[];
int Res,Num;char C,CH[];
inline int G()
{
Res=;C='*';
while(C<''||C>'')C=getchar();
while(C>=''&&C<=''){Res=Res*+(C-'');C=getchar();}
return Res;
}
inline void P(int x)
{
Num=;while(x>)CH[++Num]=x%,x/=;
while(Num)putchar(CH[Num--]+);
putchar('\n');
}
void init()
{
for(int i=;i<=n;i++)
fa[i]=i;
}
int findroot(int x)
{
if(fa[x]==x)
return x;
int rt=findroot(fa[x]);
fa[x]=rt;
return rt;
}
void Union(const int &u,const int &v)
{
if(rank[u]<rank[v])
{
fa[u]=v;
for(it=T[u].begin();it!=T[u].end();it++)
T[v].insert((*it));
T[u].clear();
}
else
{
fa[v]=u;
for(it=T[v].begin();it!=T[v].end();it++)
T[u].insert((*it));
T[v].clear();
if(rank[u]==rank[v]) rank[u]++;
}
}
int main()
{
n=G();m=G();
init();
for(int i=;i<=n;i++)
{
val[i]=G();
T[i].insert(val[i]);
num[val[i]]=i;
}
for(int i=;i<=m;i++)
{
x=G();y=G();
f1=findroot(x),f2=findroot(y);
if(f1!=f2) Union(f1,f2);
}
q=G();
for(int i=;i<=q;i++)
{
scanf("%s",op);x=G();y=G();
if(op[]=='Q')
{
f1=findroot(x);
if(T[f1].size()<y) puts("-1");
else P(num[*T[f1].find_by_order(y-)]);
}
else
{
f1=findroot(x),f2=findroot(y);
if(f1!=f2) Union(f1,f2);
}
}
return ;
}
最新文章
- 如何让spring mvc web应用启动时就执行特定处理
- 友盟ionic多渠道自动签名app
- rest api设计的一般原则
- drupal7 form模板复写方法
- wordpress插入腾讯视频的方法
- 树形DP(Holiday&#39;s Accommodation HDU4118)
- gem
- chm文件访问提示:已取消到该网页的导航
- 总是你 2008-3 (献给L之一)
- MYI 文件内容
- poj 1236强连通图缩点
- HDOJ 4248 A Famous Stone Collector DP
- 打开phpmyadmin显示高级功能尚未完全设置部分功能未激活
- Sublime Text3介绍和插件安装——基于Python开发
- 理解Object.defineProperty函数中的get与set
- cookies相关概念
- webserver nginx / https / upstream
- mybatis 三剑客 generator配置 、mybatis plugin
- Java WebDriver 使用经验
- gcc,g++