原文链接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的更多相关文章

  1. bzoj 2209: [Jsoi2011]括号序列 splay

    2209: [Jsoi2011]括号序列 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 833  Solved: 392[Submit][Status ...

  2. BZOJ 2209: [Jsoi2011]括号序列 [splay 括号]

    2209: [Jsoi2011]括号序列 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 1111  Solved: 541[Submit][Statu ...

  3. 【BZOJ2329/2209】[HNOI2011]括号修复/[Jsoi2011]括号序列 Splay

    [BZOJ2329/2209][HNOI2011]括号修复/[Jsoi2011]括号序列 题解:我们的Splay每个节点维护如下东西:左边有多少多余的右括号,右边有多少多余的左括号,同时为了反转操作, ...

  4. BZOJ2209: [Jsoi2011]括号序列

    传送门 splay练习. 考虑把括号序列转化成类似于区间最大/最小值的情况. 显然我们可以知道括号序列消完的情况肯定是$a$个)和$b$个(,那么把这些括号全部合法化的代价显然就是$\frac{a+1 ...

  5. bzoj 2209 [Jsoi2011]括号序列 平衡树

    2209: [Jsoi2011]括号序列 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 1404  Solved: 699[Submit][Statu ...

  6. 【BZOJ】2209: [Jsoi2011]括号序列(splay)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2209 splay又犯逗........upd1那里的sum忘记赋值反............. 本题 ...

  7. 【BZOJ-2329&2209】括号修复&括号序列 Splay

    2329: [HNOI2011]括号修复 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 1007  Solved: 476[Submit][Statu ...

  8. [BZOJ3786] 星系探索(括号序列+Splay)

    3786: 星系探索 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 2191  Solved: 644[Submit][Status][Discuss ...

  9. [HNOI2011]括号修复 / [JSOI2011]括号序列

    传送门 Solution 一道题花费了两天的时间-- 在大佬@PinkRabbit的帮助下,终于AC了,感动-- 首先,我们考虑一个括号序列被修改成合法序列需要的次数: 我们需要修改的其实是形如... ...

随机推荐

  1. mysql:赋予用户权限、查看及修改端口号

    一.mysql 赋给用户权限 grant all privileges on *.* to joe@localhost identified by '1'; flush privileges; 即用u ...

  2. [C]变量作用域

    函数环境变量作用域 C语言栈环境变量作用域跟JS是类似的. 就是内部函数可以访问外部函数的执行(栈)环境变量. 当访问一个变量时,程序将会查询当前栈环境是否存在这个变量,如果没有,将会往上层栈环境继续 ...

  3. C#结婚吧(if else if)

  4. Confluence 6 查看空间活动

    空间活动信息是默认禁用(disabled by default)的.活动(Activity)的标没有显示,如果你的 Confluence Usage Stats  插件没有启用的.请查看下面的说明: ...

  5. Confluence 6 使用 JConsole 监控远程 Confluence

    针对生产系统中,我们推荐你使用远程监控,这个将不会消耗你远程 Confluence 服务器的资源. 启动远程监控: 添加下面的属性到 setenv.sh / setenv.bat 文件中,端口你可以定 ...

  6. Guideline 5.2.1 - Legal - Intellectual Property 解决方案

    最近在上架公司公司项目的时候遇到这个问题什么5.2.1 然后去了解发现最近不少人都遇到了这个问题.先说一下 我上架的APP是一个医疗的APP然后说需要什么医疗资质,估计是账号的公司资质不够吧.后面和苹 ...

  7. Java编制至今总结和学习报告

    日期:2018.8.19 星期日 博客期:006 说个事,本来想把博客园做一个交流平台的,可是交流度有点少...嗯...我看我还是把这个平台当作经验传授平台和自己的作品发布平台吧!Java的知识详解, ...

  8. python Requests 的一些高级特性

    会话对象 会话对象让你能够跨请求保持某些参数.它也会在同一个 Session 实例发出的所有请求之间保持 cookie, 期间使用 urllib3 的 connection pooling 功能.所以 ...

  9. verilog-产生axis数据流

    首先这是产生aixs数据流的代码 `timescale 1ps/1ps `default_nettype none module axis_switch_0_example_master #( ) ( ...

  10. 工业以太网EtherNet/IP协议安全分析整理

    1.     EtherNet/IP : 设备可以用户数据报协议(UDP)的隐式报文传送基于IO的资料 ,用户传输控制协议(TCP)显示报文上传和下参数,设定值,程式 ,用户主站的轮询 从站周期性的更 ...