bzoj4764: 弹飞大爷
Description
Input
Output
对边界外新建一个点表示,设其后继为自身,则只需维护动态基环内向森林,支持修改点的后继,查询点是否在特定联通块中,若是则查询深度
对每个联通块,必有一个环,任意断掉一条环边,用平衡树维护剩余部分对应的的括号序列,查询深度即为括号序列的前缀和,修改后继时需要分类讨论一下
#include<cstdio>
const int N=;
#define G *++ptr
char buf[N*],*ptr=buf-;
int _(){
int x=,c=G,f=;
while(c<)c=='-'&&(f=-),c=G;
while(c>)x=x*+c-,c=G;
return x*f;
}
int n,q,ch[N*][],nx[N],r1,r2,r3;
#define lc ch][0
#define rc ch][1
#define fa ch][2
#define val ch][3
#define sum ch][4
void up(int x){
x[sum]=x[val]+x[lc][sum]+x[rc][sum];
}
void rot(int w){
int f=w[fa],d=(w!=f[lc]),g=f[fa];
if(g)g[ch][g[lc]!=f]=w;
w[fa]=g;
(f[ch][d]=w[ch][d^])[fa]=f;
(w[ch][d^]=f)[fa]=w;
up(f),up(w);
}
void sp(int x){
while(x[fa]){
int f=x[fa];
if(f[fa])rot((x==f[rc])==(f==f[fa][rc])?f:x);
rot(x);
}
}
int gl(int x){
while(x[lc])x=x[lc];
sp(x);
return x;
}
int grt(int x){
int a=x;
while(x[fa])x=x[fa];
sp(a);
return x;
}
int mg(int a,int b){
if(!a||!b)return a|b;
b=gl(b);
(b[lc]=a)[fa]=b;
up(b);
return b;
}
void ct_l(int w,int&a,int&b){sp(w);a=w[lc];b=w;a[fa]=w[lc]=;up(w);}
void ct_r(int w,int&a,int&b){sp(w);b=w[rc];a=w;b[fa]=w[rc]=;up(w);}
void lk(int x,int y){
x<<=;y<<=;
sp(y);
if(grt(x)==y)return;
ct_r(y,r1,r2);
sp(x);
mg(mg(r1,x),r2);
}
void ct(int x){
x<<=;
sp(x);
int rt=gl(x);
if(x==rt)return;
ct_l(x,r1,r2);
ct_r(x^,r2,r3);
mg(r1,r3);
if(grt(nx[rt>>]<<)==r2)lk(rt>>,nx[rt>>]);
}
int get(int x){
x<<=;
sp(x);
int r=x[lc][sum];
printf("%d\n",gl(x)==(n+<<)?r:-);
}
int F(int x){return x>&&x<=n?x:n+;}
int main(){
buf[fread(buf,,sizeof(buf),stdin)]=;
n=_();q=_();
for(int i=;i<=n;++i)nx[i]=F(i+_());
nx[n+]=n+;
for(int i=;i<=n+;++i){
int l=i<<,r=l^;
l[val]=;
r[sum]=r[val]=-;
(l[rc]=r)[fa]=l;
}
for(int i=;i<=n;++i)lk(i,nx[i]);
while(q--){
if(_()==){
int x=_();
get(x);
}else{
int x=_(),y=x+_();
nx[x]=F(y);
ct(x);
lk(x,nx[x]);
}
}
return ;
}
bzoj4764: 弹飞大爷的更多相关文章
- 【LCT维护基环内向树森林】BZOJ4764 弹飞大爷
4764: 弹飞大爷 Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 101 Solved: 52[Submit][Status][Discuss] ...
- BZOJ4764弹飞大爷——LCT
题目描述 自从WC退役以来,大爷是越来越懒惰了.为了帮助他活动筋骨,也是受到了弹飞绵羊一题的启发,机房的小伙伴们 决定齐心合力构造一个下面这样的序列.这个序列共有N项,每项都代表了一个小伙伴的力量值, ...
- bzoj4764 弹飞大爷 LCT
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4764 题解 如果 \(a_i > 0\) 的话,那么就是 bzoj2002 的原题.直接 ...
- bzoj4764: 弹飞大爷 link-cut-tree
题目传送门 这道题啊 调了一个晚上 因为写的是一个有根树和n个基环的写法 所以写得很奇怪..... 最后发现单独处理树的时候不能随意改变S(就是原来的根)不然size会出错.... #include& ...
- 【BZOJ4764】弹飞大爷 LCT
[BZOJ4764]弹飞大爷 Description 自从WC退役以来,大爷是越来越懒惰了.为了帮助他活动筋骨,也是受到了弹飞绵羊一题的启发,机房的小伙伴们决定齐心合力构造一个下面这样的序列.这个序列 ...
- BZOJ 4764: 弹飞大爷
4764: 弹飞大爷 Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 4 Solved: 4[Submit][Status][Discuss] Des ...
- 【bzoj 4764】弹飞大爷
Description 自从WC退役以来,大爷是越来越懒惰了.为了帮助他活动筋骨,也是受到了弹飞绵羊一题的启发,机房的小伙伴们决定齐心合力构造一个下面这样的序列.这个序列共有N项,每项都代表了一个小伙 ...
- 【BZOJ】4764: 弹飞大爷 LCT
[题意]给定n个数字ai,表示大爷落到i处会被弹飞到i+ai处,弹飞到>n或<1处则落地.m次操作,修改一个ai,或询问大爷落到x处经过几次落地(或-1).n,m<=10^5,|ai ...
- 【BZOJ4764】弹飞大爷
题解: 这个应该还是比较简单的 首先比较容易想到用lct来维护 我们可以建立一个特殊点 然后我们要处理环 其实只要判断它和不和这个特殊点联通就行了 那么当它不是环了我们怎么还原呢 只要对每个在根节点记 ...
随机推荐
- 第5课:内置函数、处理json、常用模块
1. 内置函数 1)常用的内置函数 print(all([0, 2, 3, 4])) # False,判断可迭代的对象里面的值是否都为真 print(any([0, 1, 2, 3, 4])) # T ...
- MoreEffectiveC++Item35 条款26: 限制某个class所能产生的对象个数
一 允许零个或一个对象 我们知道每当即将产生一个对象,我们有一个constructor被调用,那么我们现在想组织某个对象的产生,最简单的方法就是将其构造函数声明成private(这样做同事防止了这个类 ...
- MB到片组的映射
待分析 链接原文: http://blog.csdn.net/mr_phy/article/details/61638262
- [置顶]
Deep Learning 资料库
一.文章来由 网络好文章太多,而通过转载文章做资料库太麻烦,直接更新这个博文. 二.汇总 1.台大李宏毅老师的课 正片:http://speech.ee.ntu.edu.tw/~tlkagk/cour ...
- SVN 安装配置详解,包含服务器和客户端,外带一个项目演示,提交,更改,下载历史版本,撤销
本次要介绍的是svn版本管理工具包含2个: 服务器端:visualsvn server 下载地址为:https://www.visualsvn.com/server/download/ 此处演示的 ...
- zookeeper 学习命令
ls /TianheSoft/nodesls /TianheSoft/nodes/localhost_2181-0000000000ls /TianheSoft/propsls /TianheSoft ...
- Debian 8 Jessie desktop on arm
/********************************************************************* * Debian 8 Jessie desktop on ...
- 【剑指offer】翻转单词顺序,C++实现
原创博文,转载请注明出处! 本题牛客网地址 本题代码的github地址 本系列文章的索引地址 # 题目 # 思路 两次翻转,第一次翻转整个句子,第二次翻转每个单词(单词之间用逗号隔开) # ...
- 【javacript】获得点击的标签
document.getElementById('content').onclick = function(e) { e = e || window.event; var target = e.tar ...
- JAVA多线程------用1
火车上车厢的卫生间,为了简单,这里只模拟一个卫生间,这个卫生间会被多个人同时使用,在实际使用时,当一个人进入卫生间时则会把卫生间锁上,等出来时 打开门,下一个人进去把门锁上,如果有一个人在卫生间内部则 ...