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了,感动-- 首先,我们考虑一个括号序列被修改成合法序列需要的次数: 我们需要修改的其实是形如... ...
随机推荐
- telnet mysql时出现:is not allowed to connect to this MySQL serverConnection closed by foreign host问题的解决
有时候telnet一个mysql服务器的时候会出现: Host '192.168.0.1' is not allowed to connect to this MySQL serverConnecti ...
- Goland could not launch process: decoding dwarf section info at offset 0x0: too short 解决方案
1 前言 Goland版本:2018.1.5 Go:1.11.2 此版本调试不了bug,而且有时会显示could not launch process: decoding dwarf section ...
- js获取当前星期几
使用Date对象的getDay方法可以获取当前日期的星期数. getDay() 方法可返回表示星期的某一天的数字. 示例: var date = new Date(); alert(date.getD ...
- Oracle的AES加密与解密用法
Oracle的AES加密与解密用法2013年12月11日 11:50:35 iteye_751 阅读数:428--加密字符串create or replace function des3_enc( i ...
- 坚持:学习Java后台的第一阶段,我学习了那些知识
最近的计划是业余时间学习Java后台方面的知识,发现学习的过程中,要学的东西真多啊,让我一下子感觉很遥远.但是还好我制定了计划,自己选择的路,跪着也要走完!关于计划是<终于,我还是下决心学Jav ...
- 使用XIB 或者storyboard 创建imageView 模式 UIViewContentModeScaleAspectFill 图片越界问题
ImageView UIViewContentModeScaleAspectFill 超出边界的问题 代码如下 [_photoView setClipsToBounds:Yes]; sto ...
- javascript中的字符串对象
1.javascript的对象的概念 在javascript中,除了null和undefined以处,其他的数据类型都被定义成了对象 也可以用创建对象的方法定义变量,string,math,array ...
- Confluence 6 通过 SSL 或 HTTPS 运行 - 修改你 Confluence 的 server.xml 文件
下一步你需要配置 Confluence 来使用 HTTPS: 编辑 <install-directory>/conf/server.xml 文件. 取消注释下面的行: <Connec ...
- python之通过thread来实现多进程
代码如下: import threading, time class Test1(threading.Thread): def __init__(self, name): super().__init ...
- bat如何创建多级文件夹(在android设备中)
在android设备中要创建多个或者多级文件夹时,手动去创建费时费力(有点傻),一个bat文件就能很好的实现这个功能. 1.首先创建同级多个文件夹且在该文件夹下生成一个文件 @echo off ech ...