BZOJ2209: [Jsoi2011]括号序列
splay练习。
考虑把括号序列转化成类似于区间最大/最小值的情况。
显然我们可以知道括号序列消完的情况肯定是$a$个)和$b$个(,那么把这些括号全部合法化的代价显然就是$\frac{a+1}{2}+\frac{b+1}{2}$。
接着我们可以把'('变为1,把')'变为-1,然后每次取左区间的连续最小值,右区间的连续最大值,就是$a$与$b$的大小。
因为存在区间翻转,所以需要把左/右区间的连续最大/小值都搞出来。
splay即可。
//BZOJ2209
//by Cydiater
//2017.2.15
#include <iostream>
#include <iomanip>
#include <cstring>
#include <string>
#include <queue>
#include <map>
#include <cmath>
#include <ctime>
#include <cstdlib>
#include <cstdio>
#include <algorithm>
#include <bitset>
#include <set>
#include <vector>
#include <complex>
using namespace std;
#define ll long long
#define up(i,j,n) for(int i=j;i<=n;i++)
#define down(i,j,n) for(int i=j;i>=n;i--)
#define cmax(a,b) a=max(a,b)
#define cmin(a,b) a=min(a,b)
const int MAXN=1e5+5;
const int oo=0x3f3f3f3f;
inline int read(){
char ch=getchar();int x=0,f=1;
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int root,cnt=0,N,M,arr[MAXN];
char s[MAXN];
struct SplayTree{
int son[2],l0,l1,r0,r1,sum,fa,siz,tag0,tag1,val;
}t[MAXN];
namespace solution{
inline int get(int k){return t[t[k].fa].son[1]==k;}
inline void reload(int k){
int s1=t[k].son[0],s2=t[k].son[1];
t[k].l0=min(t[s1].l0,t[s1].sum+t[k].val+t[s2].l0);
t[k].l1=max(t[s1].l1,t[s1].sum+t[k].val+t[s2].l1);
t[k].r0=min(t[s2].r0,t[s2].sum+t[k].val+t[s1].r0);
t[k].r1=max(t[s2].r1,t[s2].sum+t[k].val+t[s1].r1);
t[k].siz=t[s1].siz+t[s2].siz+1;
t[k].sum=t[s1].sum+t[s2].sum+t[k].val;
}
inline void push0(int k){
if(!k)return;
swap(t[k].l0,t[k].l1);t[k].l0*=-1;t[k].l1*=-1;
swap(t[k].r0,t[k].r1);t[k].r0*=-1;t[k].r1*=-1;
t[k].tag0^=1;t[k].val*=-1;t[k].sum*=-1;
}
inline void push1(int k){
if(!k)return;
swap(t[k].l0,t[k].r0);
swap(t[k].l1,t[k].r1);
t[k].tag1^=1;
}
inline void Pushdown(int k){
int s1=t[k].son[0],s2=t[k].son[1];
if(t[k].tag1){
push1(s1);push1(s2);
swap(t[k].son[0],t[k].son[1]);
t[k].tag1=0;
}
if(t[k].tag0){
push0(s1);push0(s2);
t[k].tag0=0;
}
}
inline void rotate(int k){
int old=t[k].fa,oldf=t[old].fa,which=get(k);
t[old].son[which]=t[k].son[which^1];t[t[old].son[which]].fa=old;
t[k].son[which^1]=old;t[old].fa=k;
t[k].fa=oldf;
if(oldf)t[oldf].son[t[oldf].son[1]==old]=k;
reload(old);reload(k);
}
inline void splay(int k,int aim){
for(int fa;(fa=t[k].fa);rotate(k)){
if(k==aim)break;
else if(fa==aim){
rotate(k);
break;
}else if(t[fa].fa==aim){
rotate(get(fa)==get(k)?fa:k);
rotate(k);
break;
}else rotate(get(fa)==get(k)?fa:k);
}
if(aim==root)root=k;
}
int Node(int rnk){
int now=root;
while(true){
Pushdown(now);
int lsiz=t[now].son[0]?t[t[now].son[0]].siz:0;
if(rnk<=lsiz)now=t[now].son[0];
else{
if(rnk==lsiz+1)return now;
rnk-=lsiz+1;
now=t[now].son[1];
}
}
}
int Match(int L,int R){
int kl=Node(L),kr=Node(R+2);
splay(kl,root);splay(kr,t[root].son[1]);
return kr;
}
void Build(int L,int R,int &k,int fa){
if(!k)k=++cnt;
int mid=(L+R)>>1;
t[k].fa=fa;t[k].siz=1;t[k].tag0=t[k].tag1=0;
t[k].l0=t[k].l1=t[k].r0=t[k].r1=0;t[k].val=arr[mid];
if(L==R){
t[k].son[0]=t[k].son[1]=0;
t[k].sum=t[k].val;
t[k].l0=t[k].l1=t[k].r0=t[k].r1=t[k].val;
cmin(t[k].l0,0);cmin(t[k].r0,0);
cmax(t[k].l1,0);cmax(t[k].r1,0);
return;
}
if(L<=mid-1)Build(L,mid-1,t[k].son[0],k);
if(mid+1<=R)Build(mid+1,R,t[k].son[1],k);
reload(k);
}
int Col(int L,int R){
int k=Match(L,R);
return ((t[t[k].son[0]].r1+1)/2)-((t[t[k].son[0]].l0-1)/2);
}
void Inv(int L,int R){
int k=Match(L,R);
push0(t[k].son[0]);
reload(k);reload(t[k].fa);
}
void Rev(int L,int R){
int k=Match(L,R);
push1(t[k].son[0]);
reload(k);reload(t[k].fa);
}
void Prepare(){
N=read();M=read();
scanf("%s",s+1);
up(i,1,N)arr[i]=(s[i]=='('?1:-1);
arr[0]=0;arr[N+1]=0;
Build(0,N+1,root,0);
}
void Solve(){
//DEBUG(root);
while(M--){
int op=read(),L=read(),R=read();
if(op==0)printf("%d\n",Col(L,R));
if(op==1)Inv(L,R);
if(op==2)Rev(L,R);
}
}
}
int main(){
using namespace solution;
Prepare();
Solve();
return 0;
}
BZOJ2209: [Jsoi2011]括号序列的更多相关文章
- BZOJ2209 [Jsoi2011]括号序列 splay
原文链接http://www.cnblogs.com/zhouzhendong/p/8093556.html 题目传送门 - BZOJ2209 题解 我太弱了,调出这题感觉都要吐了. 题解懒得写了. ...
- 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 ...
- bzoj 2209 [Jsoi2011]括号序列 平衡树
2209: [Jsoi2011]括号序列 Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 1404 Solved: 699[Submit][Statu ...
- 【BZOJ2329/2209】[HNOI2011]括号修复/[Jsoi2011]括号序列 Splay
[BZOJ2329/2209][HNOI2011]括号修复/[Jsoi2011]括号序列 题解:我们的Splay每个节点维护如下东西:左边有多少多余的右括号,右边有多少多余的左括号,同时为了反转操作, ...
- 【BZOJ】2209: [Jsoi2011]括号序列(splay)
http://www.lydsy.com/JudgeOnline/problem.php?id=2209 splay又犯逗........upd1那里的sum忘记赋值反............. 本题 ...
- [HNOI2011]括号修复 / [JSOI2011]括号序列
传送门 Solution 一道题花费了两天的时间-- 在大佬@PinkRabbit的帮助下,终于AC了,感动-- 首先,我们考虑一个括号序列被修改成合法序列需要的次数: 我们需要修改的其实是形如... ...
- 洛谷 P3215 [HNOI2011]括号修复 / [JSOI2011]括号序列(fhq-treap)
题目链接 题意:有一个长度为 \(n\) 的括号序列,你需要支持以下操作: 将 \([l,r]\) 中所有括号变为 \(c\) 将 \([l,r]\) 区间翻转 将 \([l,r]\) 区间中左括号变 ...
- ●BZOJ 2209 [Jsoi2011]括号序列
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2209 题解: Splay 很好的题,但是把智障的我给恶心到了... 首先不难发现,最后没 ...
随机推荐
- 关于线上js报错问题的思考
1.有没有可能对线上报错进行实时监控,只要线上报错出现就会以邮件的形式发出来. 2.有没有可能将每个模块和开发者联系起来,只要报错就直接报给开发者
- Mysql group_concat函数列转行,与行转列
例一: SELECT num from user 1.使用group_concat函数得到列转行 select group_concat(num) from user 2.使用SUBSTRING_IN ...
- 【BZOJ2957】楼房重建 分块
[BZOJ2957]楼房重建 Description 小A的楼房外有一大片施工工地,工地上有N栋待建的楼房.每天,这片工地上的房子拆了又建.建了又拆.他经常无聊地看着窗外发呆,数自己能够看到多少栋房子 ...
- Unity3D笔记四 基础知识概念
1. Project视图 主要存放游戏中用到的所有资源文件,常见的包括:游戏脚本.预设.材质.动画.自定义字体.纹理.物理材质和GUI皮肤等. 1> Folder: 文件夹,用于资源的分 ...
- 微信小程序 --- 获取设备信息
获取设备信息: wx.getSystemInfo model:手机型号 pixelRatio:设备像素比 windowWidth:窗口宽度 windowHeight:窗口高度 language:语言 ...
- mysql 使用如下三种方式应用where条件,从好到坏
在索引中使用where条件过滤不匹配的记录,这是在存储引擎层完成的: 使用索引覆盖扫描(explain语句中的Extra列中出现Using index)来返回记录.直接从索引中过滤掉不需要的记录并返 ...
- 洛谷P2444 病毒【AC自动机】
题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已经找出了所有的病毒代码段,试问,是否 ...
- 使用jquery的$.post()时浏览器崩溃
代码: function verifyStepOne() { var phoneNumber = $("#phoneNumber"); var username = $(" ...
- python基础===包的导入和__init__.py的介绍
转自:https://www.cnblogs.com/botoo/p/8241522.html 调用同级目录: – src |– mod.py |– test.py 若在程序test.py中导入模块m ...
- Python开发【模块】:time、datatime
时间模块 时间相关的操作,时间有三种表示方式: 时间戳 1970年1月1日之后的秒,即:time.time() 格式化的字符串 2014-11-11 11:11, ...