bzoj 1251: 序列终结者 平衡树,fhqtreap
链接
https://www.lydsy.com/JudgeOnline/problem.php?id=1251
思路
好简单的模板题
不过还是wrong了好几发
叶子节点要注意下,不能使用
遇到就不管
写的fhq-treap,OI中常数最大的平衡树,中间还T了一发
代码
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <cstdio>
using namespace std;
const int N=5e5+7;
int read() {
int x=0,f=1;char s=getchar();
for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
int n,m;
int ch[N][2],val[N],pri[N],siz[N],ma[N],tag_1[N],tag_2[N];
int max(int a,int b) {
return a>b?a:b;
}
void work1(int rt) {
if(!rt) return;
swap(ch[rt][0],ch[rt][1]);
tag_1[rt]^=1;
}
void work2(int rt,int k) {
if(!rt) return;
val[rt]+=k;
ma[rt]+=k;
tag_2[rt]+=k;
}
void pushdown(int rt) {
if(tag_1[rt]) {
work1(ch[rt][0]);
work1(ch[rt][1]);
tag_1[rt]=0;
}
if(tag_2[rt]) {
work2(ch[rt][0],tag_2[rt]);
work2(ch[rt][1],tag_2[rt]);
tag_2[rt]=0;
}
}
void pushup(int rt) {
ma[rt]=max(val[rt],max(ma[ch[rt][0]],ma[ch[rt][1]]));
siz[rt]=siz[ch[rt][0]]+siz[ch[rt][1]]+1;
}
int cnt;
int build(int l,int r) {
if(l>r) return 0;
int mid=(l+r)>>1,p=++cnt;
ma[p]=val[p]=0,pri[p]=rand(),siz[p]=1;
ch[p][0]=build(l,mid-1);
ch[p][1]=build(mid+1,r);
if(!ch[p][0]) ma[ch[p][0]]=-0x3f3f3f3f;
if(!ch[p][1]) ma[ch[p][1]]=-0x3f3f3f3f;
pushup(p);
return p;
}
int merge(int x,int y) {
pushdown(x),pushdown(y);
if(!x||!y) return x+y;
if(pri[x]<pri[y]) {
ch[x][1]=merge(ch[x][1],y);
pushup(x);
return x;
} else {
ch[y][0]=merge(x,ch[y][0]);
pushup(y);
return y;
}
}
void split(int now,int &x,int &y,int k) {
if(!now) x=y=0;
else {
pushdown(now);
if(siz[ch[now][0]]+1<=k)
x=now,split(ch[now][1],ch[x][1],y,k-siz[ch[now][0]]-1);
else
y=now,split(ch[now][0],x,ch[y][0],k);
pushup(now);
}
}
void debug(int now ){
pushdown(now);
if(!now) return;
debug(ch[now][0]);
cout<<val[now]<<" ";
debug(ch[now][1]);
}
int main() {
n=read(),m=read();
int rt=build(1,n);
for(int i=1;i<=m;++i) {
int opt=read(),l=read(),r=read(),x,y,z;
if(opt==1) {
int v=read();
split(rt,x,z,r);
split(x,x,y,l-1);
work2(y,v);
rt=merge(merge(x,y),z);
}
else if(opt==2) {
split(rt,x,z,r);
split(x,x,y,l-1);
work1(y);
rt=merge(merge(x,y),z);
} else {
split(rt,x,z,r);
split(x,x,y,l-1);
printf("%d\n",ma[y]);
rt=merge(merge(x,y),z);
}
// debug(rt);puts("");
}
return 0;
}
/*
10 3
1 3 9 -5705
2 2 6
3 7 8
*/
bzoj 1251: 序列终结者 平衡树,fhqtreap的更多相关文章
- BZOJ 1251 序列终结者(Splay)
题目大意 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术 ...
- BZOJ 1251: 序列终结者 [splay]
1251: 序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 3778 Solved: 1583[Submit][Status][Discu ...
- BZOJ 1251: 序列终结者
1251: 序列终结者 Time Limit: 20 Sec Memory Limit: 162 MB Submit: 3773 Solved: 1579 [Submit][Status][Dis ...
- bzoj 1251序列终结者 splay 区间翻转,最值,区间更新
序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 4594 Solved: 1939[Submit][Status][Discuss] De ...
- 【BZOJ】1251: 序列终结者(splay)
http://www.lydsy.com/JudgeOnline/problem.php?id=1251 不行..为什么写个splay老是犯逗,这次又是null的mx没有赋值-maxlongint.. ...
- 1251. 序列终结者【平衡树-splay】
Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这 ...
- 【BZOJ】1251: 序列终结者
[题意]给定含有n个0的的数列. 1.区间加值 2.区间翻转 3.区间求最大值 [算法]平衡树(fhq-treap) 需要特别注意的是: 1.使0点对全局无影响并全程保持(例如求max,t[0].mx ...
- 【bzoj1251】序列终结者(伸展树)
[bzoj1251]序列终结者(伸展树) Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我 ...
- 【BZOJ】【1251】序列终结者
Splay 还是splay序列维护,这题我WA了的原因是:在Push_up的时候,当前子树的max我是直接取的L.R和v[x]的最大值,但是如果没有左/右儿子,默认是会访问0号结点的mx值,而这个值没 ...
随机推荐
- hbase-java-api002(flush)
package api; import java.io.IOException; import org.apache.hadoop.conf.Configuration; import org.apa ...
- netcore swagger xml发布丢失问题
1.netcore2.1.2,swagger.aspnetcore 1.1.0版本.发布netcore项目时swagger的接口文档xml 遗漏,始终发布不上去.后来查阅资料,讲的好像是netcore ...
- 去掉idea中竖线
1.现象如下: 2.解决办法. 3.解决后如下:
- <4>Cocos Creator基本概念(场景树 节点 坐标 组件 )
1.场景树 Cocos Creator是由一个一个的游戏场景组成,场景是一个树形结构,场景由 有各种层级关系的节点(下一节有具有介绍)组成: 如创建一个HelloWorld的默认项目NewProjec ...
- 三 js语句
/** * Created by Administrator on 2017/12/24. * 1.顺序语句 * 2.选择语句 if else swtich case * 3.循环语句 for whi ...
- ASCII 码
http://baike.baidu.com/link?url=Y4crTsVq678Z8fr92DAGIrqVHoexVXsMc-WKBMVUKGDq4KbEOuhWbUQXuQEtnlom4yln ...
- CSS选择符-----伪类选择符
Element:hover E:hover { sRules } 设置元素在其鼠标悬停时的样式 <!DOCTYPE html> <html> <head> < ...
- 浅谈大数据与hadoop家族
按照时间的早晚从大数据出现之前的时代讲到现在.暂时按一个城市来比喻吧,反正Landscape的意思也大概是”风景“的意思. 早在大数据概念出现以前就存在了各种各样的关于数学.统计学.算法.编程语言的研 ...
- JAVA中异常状况总结
之前在<会当凌绝顶>这本书中学到过对于异常处理的知识,当时也是根据书上的代码,自己进行编写大概知道是怎么回事儿,王老师给我们上了一节课之后,发现异常处理可以发挥很大的作用. 通过在网络上 ...
- SpringMVC七种参数绑定简单介绍
a. 默认支持的类型: httpServletRequest, httpservletresponse, httpsession, model 看自己需要, 如果需要用就加 ...