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来维护 我们可以建立一个特殊点 然后我们要处理环 其实只要判断它和不和这个特殊点联通就行了 那么当它不是环了我们怎么还原呢 只要对每个在根节点记 ...
随机推荐
- hdu 5800 To My Girlfriend(背包变形)
To My Girlfriend Time Limit: 2000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- Idea_01_安装与激活
一.前言 二.安装 1.下载 https://www.jetbrains.com/idea/ 2.安装 默认安装即可 三.激活 Idea激活有如下两种方式 Activation code Lisenc ...
- 《Effective C++》第2章 构造/析构/赋值运算(1)-读书笔记
章节回顾: <Effective C++>第1章 让自己习惯C++-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(1)-读书笔记 <Effecti ...
- powershell -enc参数无法解码base64编码payload的解决方案
powershell的-enc参数允许传入一个base64编码过的powershell脚本字符串作为参数来执行该powershell脚本,该方法常被用于绕过杀毒软件的主动防御机制. 今天下午在做一个后 ...
- TypeError: pivot_table() got an unexpected keyword argument 'rows'
利用Python进行数据分析>第二章,处理MovieLens 1M数据集,有句代码总是报错: mean_rating = data.pivot_table('rating', rows='tit ...
- Android组件化开发实践
转载请注明出处:http://blog.csdn.net/crazy1235/article/details/76533115 http://mdsa.51cto.com/art/201707/544 ...
- Android 开发 Tip 17 -- 为什么getBackground().setAlpha(); 会影响别的控件?
转载请注明出处:http://blog.csdn.net/crazy1235/article/details/75670018 http://www.jb51.net/article/110035.h ...
- matplotlib 数据可视化
图的基本结构 通常,使用 numpy 组织数据, 使用 matplotlib API 进行数据图像绘制. 一幅数据图基本上包括如下结构: Data: 数据区,包括数据点.描绘形状 Axis: 坐标轴, ...
- phpcms v9取消验证码
phpcms/modules/admin/index.php// $code = isset($_POST['code']) && trim($_POST['code']) ? tri ...
- lx 与cd 的计算方法
Candela to lux calculation with distance in meters The illuminance Ev in lux (lx) is equal to the lu ...