BZOJ2209 [Jsoi2011]括号序列 splay
原文链接http://www.cnblogs.com/zhouzhendong/p/8093556.html
题目传送门 - BZOJ2209
题解
我太弱了,调出这题感觉都要吐了。
题解懒得写了。
给一个链接:
http://blog.csdn.net/lych_cys/article/details/50700277
代码
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <cstdlib>
#include <cmath>
using namespace std;
const int N=100005;
int fa[N],son[N][2],rev1[N],rev2[N],root;
int Lmin[N],Lmax[N],Rmin[N],Rmax[N],sum[N],val[N],size[N];
void pushup(int x){
int ls=son[x][0],rs=son[x][1];
sum[x]=sum[ls]+val[x]+sum[rs];
size[x]=size[ls]+size[rs]+1;
Lmin[x]=min(Lmin[ls],sum[ls]+val[x]+Lmin[rs]);
Lmax[x]=max(Lmax[ls],sum[ls]+val[x]+Lmax[rs]);
Rmin[x]=min(Rmin[rs],sum[rs]+val[x]+Rmin[ls]);
Rmax[x]=max(Rmax[rs],sum[rs]+val[x]+Rmax[ls]);
}
int build(int pre,int L,int R){
if (L>R)
return 0;
int mid=(L+R)>>1;
fa[mid]=pre;
if (L==R){
Lmin[mid]=Rmin[mid]=Lmax[mid]=Rmax[mid]=0;
sum[mid]=val[mid],size[mid]=1;
if (val[mid]<0)
Lmin[mid]=Rmin[mid]=-1;
if (val[mid]>0)
Lmax[mid]=Rmax[mid]=1;
return mid;
}
son[mid][0]=build(mid,L,mid-1);
son[mid][1]=build(mid,mid+1,R);
pushup(mid);
return mid;
}
void pushson(int x,int r1,int r2){
if (!x)
return;
if (r1){
rev1[x]^=1;
swap(Lmin[x],Lmax[x]),Lmin[x]=-Lmin[x],Lmax[x]=-Lmax[x];
swap(Rmin[x],Rmax[x]),Rmin[x]=-Rmin[x],Rmax[x]=-Rmax[x];
sum[x]=-sum[x];
val[x]=-val[x];
}
if (r2){
rev2[x]^=1;
swap(Lmin[x],Rmin[x]);
swap(Lmax[x],Rmax[x]);
swap(son[x][0],son[x][1]);
}
}
void pushdown(int x){
int &ls=son[x][0],&rs=son[x][1],&r1=rev1[x],&r2=rev2[x];
pushson(ls,r1,r2);
pushson(rs,r1,r2);
r1=r2=0;
}
void pushadd(int x){
if (fa[x])
pushadd(fa[x]);
pushdown(x);
}
int wson(int x){
return son[fa[x]][1]==x;
}
void rotate(int x){
if (!fa[x])
return;
int y=fa[x],z=fa[y],L=wson(x),R=L^1;
if (z)
son[z][wson(y)]=x;
fa[x]=z,fa[y]=x,fa[son[x][R]]=y;
son[y][L]=son[x][R],son[x][R]=y;
pushup(y),pushup(x);
}
void splay(int x,int rt){
if (!x)
return;
if (!rt)
root=x;
pushadd(x);
for (int y=fa[x];fa[x]!=rt;rotate(x),y=fa[x])
if (fa[y]!=rt)
rotate(wson(x)==wson(y)?y:x);
}
int findkth(int x,int k){
pushdown(x);
if (size[son[x][0]]+1==k)
return x;
if (k<=size[son[x][0]])
return findkth(son[x][0],k);
else
return findkth(son[x][1],k-size[son[x][0]]-1);
}
int n,m;
char str[N];
int main(){
scanf("%d%d%s",&n,&m,str+2);
memset(val,0,sizeof val);
for (int i=2;i<=n+1;i++)
val[i]=str[i]=='('?1:-1;
root=build(0,1,n+2);
for (int i=1;i<=m;i++){
int op,x,y;
scanf("%d%d%d",&op,&x,&y);
x=findkth(root,x),y=findkth(root,y+2);
splay(x,0);
splay(y,x);
int z=son[y][0];
if (op==0)
printf("%d\n",(Rmax[z]+1)/2-(Lmin[z]-1)/2);
if (op==1)
pushson(z,1,0);
if (op==2)
pushson(z,0,1);
}
return 0;
}
BZOJ2209 [Jsoi2011]括号序列 splay的更多相关文章
- bzoj 2209: [Jsoi2011]括号序列 splay
2209: [Jsoi2011]括号序列 Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 833 Solved: 392[Submit][Status ...
- BZOJ 2209: [Jsoi2011]括号序列 [splay 括号]
2209: [Jsoi2011]括号序列 Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 1111 Solved: 541[Submit][Statu ...
- 【BZOJ2329/2209】[HNOI2011]括号修复/[Jsoi2011]括号序列 Splay
[BZOJ2329/2209][HNOI2011]括号修复/[Jsoi2011]括号序列 题解:我们的Splay每个节点维护如下东西:左边有多少多余的右括号,右边有多少多余的左括号,同时为了反转操作, ...
- BZOJ2209: [Jsoi2011]括号序列
传送门 splay练习. 考虑把括号序列转化成类似于区间最大/最小值的情况. 显然我们可以知道括号序列消完的情况肯定是$a$个)和$b$个(,那么把这些括号全部合法化的代价显然就是$\frac{a+1 ...
- bzoj 2209 [Jsoi2011]括号序列 平衡树
2209: [Jsoi2011]括号序列 Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 1404 Solved: 699[Submit][Statu ...
- 【BZOJ】2209: [Jsoi2011]括号序列(splay)
http://www.lydsy.com/JudgeOnline/problem.php?id=2209 splay又犯逗........upd1那里的sum忘记赋值反............. 本题 ...
- 【BZOJ-2329&2209】括号修复&括号序列 Splay
2329: [HNOI2011]括号修复 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 1007 Solved: 476[Submit][Statu ...
- [BZOJ3786] 星系探索(括号序列+Splay)
3786: 星系探索 Time Limit: 40 Sec Memory Limit: 256 MBSubmit: 2191 Solved: 644[Submit][Status][Discuss ...
- [HNOI2011]括号修复 / [JSOI2011]括号序列
传送门 Solution 一道题花费了两天的时间-- 在大佬@PinkRabbit的帮助下,终于AC了,感动-- 首先,我们考虑一个括号序列被修改成合法序列需要的次数: 我们需要修改的其实是形如... ...
随机推荐
- python bytes/str
http://eli.thegreenplace.net/2012/01/30/the-bytesstr-dichotomy-in-python-3/
- linux中shell变量$#,$@,$0,$1,$2的含义解释 (转载)
变量说明: $$Shell本身的PID(ProcessID)$!Shell最后运行的后台Process的PID$?最后运行的命令的结束代码(返回值)$-使用Set命令设定的Flag一览$*所有参数列表 ...
- Laravel资源理由器跟隐式控制的对比及是怎样的吧?- Route::resource vs Route::controller
stackoverflow找到的问题:http://stackoverflow.com/questions/23505875/laravel-routeresource-vs-routecontrol ...
- python中的各种锁
一.全局解释器锁(GIL) 1.什么是全局解释器锁 在同一个进程中只要有一个线程获取了全局解释器(cpu)的使用权限,那么其他的线程就必须等待该线程的全局解释器(cpu)使 用权消失后才能使用全局解释 ...
- JS跨域ajax访问
方式1:jsonp解决跨域访问 需要服务和js配合 服务 [WebMethod] public void HelloWorld2(string name) { HttpContext.Current. ...
- Confluence 6 启用远程 API
XML-RPC 和 SOAP 远程 API 从 Confluence 5.5 开始已经废弃了.我们推荐你使用完全支持的Confluence Server REST API. 希望启用 XML-RPC ...
- Confluence 6 配置 Office 转换器
Office 连接器(Office Connector)允许 Confluence 用户能够查看和编辑从 Microsoft Office 和 Open Office 中导入并附加到页面的内容. Of ...
- Swift 中 insetBy(dx: CGFloat, dy: CGFloat) -> CGRect 用法详解
insetBy(dx: CGFloat, dy: CGFloat) -> CGRect 点击头文件进去 可以发现它是返回的一个CGRect insetBy方法是CGRect 的一个方法 dx后面 ...
- day14 迭代器 生成器 面向过程思想
"" 迭代器 什么是迭代器(iterator) 器指的某种工具, 迭代指的是更新换代的过程,例如应用程序的版本更新从1.0 变成 1.1 再1.2 迭代的目的是要根据上一个结果,产 ...
- 【python】查找函数定义
help(函数名) 举例:想知道gevnet.Timeout这个函数是怎么用的.help(gevent.Timeout). 之前不知道这样查,每次遇到新函数想知道有哪些参数我都要到网上疯狂查阅文档.现 ...