[HNOI2012]永无乡

每个联通块的点集用动态开点线段树维护

并查集维护图

合并时把线段树也合并就好了。

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cctype>
#define re register
#define gc getchar
using namespace std;
void chread(char &x){
char c=gc();
while(!isupper(c)) c=gc();
x=c;
}
void read(int &x){
char c=gc();x=; bool f=;
while(!isdigit(c)) f=(f&&c!='-'),c=gc();
while(isdigit(c)) x=(x<<)+(x<<)+(c^),c=gc();
x=f?x:-x;
}
void swap(int &a,int &b){a^=b;b^=a;a^=b;}
#define N 100002
#define M 600002
struct edge{int u,v;bool del;}b[M];
struct node{
int sum,lc,rc;
}c[M<<];
int n,m,t,u,val[N],fa[N],rt[N],ttp,id[N];
double ans; void update(int &o,int l,int r,int v,int k){//插入
if(!o) o=++u;
if(l==r) {c[o].sum+=k; return;}
int mid=l+((r-l)>>);
if(v<=mid) update(c[o].lc,l,mid,v,k);
else update(c[o].rc,mid+,r,v,k);
c[o].sum=c[c[o].lc].sum+c[c[o].rc].sum;
}
void merge(int &o,int pr){//合并
if(!o||!pr) {o+=pr;return;}
c[o].sum+=c[pr].sum;
merge(c[o].lc,c[pr].lc);
merge(c[o].rc,c[pr].rc);
}
int query(int o,int l,int r,int k){//询问
if(l==r) return l;
int mid=l+((r-l)>>);
if(k<=c[c[o].lc].sum) return query(c[o].lc,l,mid,k);
else return query(c[o].rc,mid+,r,k-c[c[o].lc].sum);
}
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
void uni(int x,int y){//并查集合并
int r1=find(x),r2=find(y);
if(r1!=r2){
merge(rt[r1],rt[r2]);
fa[r2]=r1;
}
}
int ask(int x,int k){
int ffa=find(x);
return k>c[rt[ffa]].sum ?-:id[query(rt[ffa],,n,k)];
}
int main(){
char opt; int q1,q2;
read(n); read(m);
for(re int i=;i<=n;++i){
read(val[i]),id[val[i]]=i,fa[i]=i;
update(rt[i],,n,val[i],);
}
for(re int i=;i<=m;++i) read(q1),read(q2),uni(q1,q2);
read(t);
for(re int i=;i<=t;++i){
chread(opt); read(q1); read(q2);
switch(opt){
case 'B':{uni(q1,q2); break;}
case 'Q':{printf("%d\n",ask(q1,q2)); break;}
}
}
return ;
}

bzoj2733 / P3224 [HNOI2012]永无乡(并查集+线段树合并)的更多相关文章

  1. BZOJ2733 [HNOI2012]永无乡(并查集+线段树合并)

    题目大意: 在$n$个带权点上维护两个操作: 1)在点$u,v$间连一条边: 2)询问点$u$所在联通块中权值第$k$小的点的编号,若该联通块中的点的数目小于$k$,则输出$-1$: 传送门 上周的模 ...

  2. B20J_2733_[HNOI2012]永无乡_权值线段树合并

    B20J_2733_[HNOI2012]永无乡_权值线段树合并 Description:n座岛,编号从1到n,每座岛都有自己的独一无二的重要度,按照重要度可以将这n座岛排名,名次用1到 n来表示.某些 ...

  3. bzoj 2733 永无乡 - 并查集 - 线段树

    永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以从一个岛 到达另一个岛. ...

  4. 【洛谷P3224】永无乡 并查集+Splay启发式合并

    题目大意:给定 N 个点的图,点有点权,初始有一些无向边,现在有 Q 个询问,每个询问支持动态增加一条无向边连接两个不连通的点和查询第 X 个点所在的联通块中权值第 K 大的是哪个点. 题解:学会了平 ...

  5. [bzoj2733][HNOI2012]永无乡_权值线段树_线段树合并

    永无乡 bzoj-2733 HNOI-2012 题目大意:题目链接. 注释:略. 想法: 它的查询操作非常友善,就是一个联通块内的$k$小值. 故此我们可以考虑每个联通块建一棵权值线段树. 这样的话每 ...

  6. 线段树合并+并查集 || BZOJ 2733: [HNOI2012]永无乡 || Luogu P3224 [HNOI2012]永无乡

    题面:P3224 [HNOI2012]永无乡 题解: 随便写写 代码: #include<cstdio> #include<cstring> #include<iostr ...

  7. 洛谷 P3224 [HNOI2012]永无乡 解题报告

    P3224 [HNOI2012]永无乡 题目描述 永无乡包含 \(n\) 座岛,编号从 \(1\) 到 \(n\) ,每座岛都有自己的独一无二的重要度,按照重要度可以将这 \(n\) 座岛排名,名次用 ...

  8. P3224 [HNOI2012]永无乡 题解

    P3224 [HNOI2012]永无乡 题解 题意概括 有若干集合,每个集合最初包含一个值,和一个编号1~n.两个操作:合并两个集合,查询包含值x的集合中第k大值最初的集合编号. 思路 维护集合之间关 ...

  9. BZOJ 3910 并查集+线段树合并

    思路: 1. 并查集+线段树合并 记得f[LCA]==LCA的时候 f[LCA]=fa[LCA] 2.LCT(并不会写啊...) //By SiriusRen #include <cstdio& ...

随机推荐

  1. cocos2d-x游戏引擎核心之六——绘图原理和绘图技巧

    一.OpenGL基础 游戏引擎是对底层绘图接口的包装,Cocos2d-x 也一样,它是对不同平台下 OpenGL 的包装.OpenGL 全称为 Open Graphics Library,是一个开放的 ...

  2. cocos2d-x游戏引擎核心之三——主循环和定时器

    一.游戏主循环 在介绍游戏基本概念的时候,我们曾介绍了场景.层.精灵等游戏元素,但我们却故意避开了另一个同样重要的概念,那就是游戏主循环,这是因为 Cocos2d 已经为我们隐藏了游戏主循环的实现.读 ...

  3. 预装的Office2016,文件图标表显示以及新建失败问题解决 方法

    新购买笔记本电脑,预装的office2016 学生版 启动激活后,会出现文件图标异常, 文件的类型为: ms-resource:Strings/FtaDisplayName.docx (.docx) ...

  4. 打造不死的asp木马

    作者:黑色记忆本文已发表于<黑客X档案>杂志第十期 版权归<黑客X档案>所有 转载请注明版权 想不到,前几天我才发现,我千辛万苦收集的asp木马,居然没有几个不被Kill的.常 ...

  5. JQuery事件e参数的方法preventDefault()取消默认行为

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  6. js对字符串进行加密和解密方法!

    在做一些微信小程序,或混合 app 的时候,或者是考虑到一些 JS 数据安全的问题.可能会使用到 JS 对用户信息进行缓存. 例如在开发:微信小程序对用户进行加密缓存,开发混合APP对用户信息进行加密 ...

  7. 问答项目---登陆也要做验证!(JS和PHP验证)

    简单JS示例: var login = $( 'form[name=login]' ); login.submit( function () { if (validate.loginAccount & ...

  8. 后缀树 & 后缀数组

    后缀树: 字符串匹配算法一般都分为两个步骤,一预处理,二匹配. KMP和AC自动机都是对模式串进行预处理,后缀树和后缀数组则是对文本串进行预处理. 后缀树的性质: 存储所有 n(n-1)/2 个后缀需 ...

  9. Quartz学习记录

    参考资料: 官方网站 Quartz使用总结

  10. 巧用Salt,实现CMDB配置自动发现

    随着互联网+新形势的发展,越来越多的企业步入双态(稳敏双态)IT时代,信息化环境越来越复杂,既有IOE三层架构,也有VCE.Openstack等云虚拟化架构和互联网化的分布式大数据架构.所以,企业急需 ...