2018.08.06bzoj1251: 序列终结者(非旋treap)
传送门
平衡树板子题。
直接fhqtreap打区间标记就行了。
代码:
#include<bits/stdc++.h>
#define N 50005
using namespace std;
typedef pair<int,int> res;
inline int read(){
int ans=0,w=1;
char ch=getchar();
while(!isdigit(ch)){if(ch=='-')w=-1;ch=getchar();}
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return ans*w;
}
int n,m,cnt=0,rt=0,val[N],son[N][2],siz[N],rev[N],rd[N],mx[N],add[N];
inline void pushup(int p){
siz[p]=siz[son[p][0]]+siz[son[p][1]]+1;
mx[p]=val[p];
if(son[p][0])mx[p]=max(mx[p],mx[son[p][0]]);
if(son[p][1])mx[p]=max(mx[p],mx[son[p][1]]);
}
inline int newnode(){
siz[++cnt]=1,son[cnt][0]=son[cnt][1]=0;
val[cnt]=rev[cnt]=add[N]=mx[cnt]=0,rd[cnt]=rand();
return cnt;
}
inline void pushadd(int p,int v){add[p]+=v,mx[p]+=v,val[p]+=v;}
inline void pushrev(int p){swap(son[p][0],son[p][1]),rev[p]^=1;}
inline void pushdown(int p){
if(rev[p]){
if(son[p][0])pushrev(son[p][0]);
if(son[p][1])pushrev(son[p][1]);
rev[p]=0;
}
if(add[p]){
if(son[p][0])pushadd(son[p][0],add[p]);
if(son[p][1])pushadd(son[p][1],add[p]);
add[p]=0;
}
}
inline int merge(int a,int b){
if(!a||!b)return a+b;
pushdown(a),pushdown(b);
if(rd[a]>=rd[b]){son[a][1]=merge(son[a][1],b),pushup(a);return a;}
son[b][0]=merge(a,son[b][0]),pushup(b);return b;
}
inline res split(int p,int k){
if(!p)return res(0,0);
res tmp,ans;
pushdown(p);
if(siz[son[p][0]]>=k){
tmp=split(son[p][0],k);
ans.first=tmp.first,son[p][0]=tmp.second,pushup(ans.second=p);
return ans;
}
tmp=split(son[p][1],k-siz[son[p][0]]-1);
ans.second=tmp.second,son[p][1]=tmp.first,pushup(ans.first=p);
return ans;
}
inline int rank(int p,int v){
if(!p)return 0;
pushdown(p);
if(val[p]>v)return rank(son[p][0],v);
return rank(son[p][1],v)+siz[son[p][0]]+1;
}
inline void update(){
int l=read(),r=read(),v=read();
res x=split(rt,r),y=split(x.first,l-1);
pushadd(y.second,v);
rt=merge(merge(y.first,y.second),x.second);
}
inline void reverse(){
int l=read(),r=read();
res x=split(rt,r),y=split(x.first,l-1);
pushrev(y.second);
rt=merge(merge(y.first,y.second),x.second);
}
inline void query(){
int l=read(),r=read();
res x=split(rt,r),y=split(x.first,l-1);
printf("%d\n",mx[y.second]);
rt=merge(merge(y.first,y.second),x.second);
}
inline void ins(){
int p=newnode();
rt=merge(rt,p);
}
int main(){
n=read(),m=read();
for(int i=1;i<=n;++i)ins();
while(m--){
int op=read();
if(op==1)update();
if(op==2)reverse();
if(op==3)query();
}
return 0;
}
2018.08.06bzoj1251: 序列终结者(非旋treap)的更多相关文章
- 2018.08.27 rollcall(非旋treap)
描述 初始有一个空集,依次插入N个数Ai.有M次询问Bj,表示询问第Bj个数加入集合后的排名为j的数是多少 输入 第一行是两个整数N,M 接下来一行有N个整数,Ai 接下来一行有M个整数Bj,保证数据 ...
- BZOJ1251序列终结者——非旋转treap
题目描述 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技 ...
- 2018.08.06 bzoj1500: [NOI2005]维修数列(非旋treap)
传送门 平衡树好题. 我仍然是用的fhqtreap,感觉速度还行. 维护也比线段树splay什么的写起来简单. %%%非旋treap大法好. 代码: #include<bits/stdc++.h ...
- 2018.08.05 bzoj3223: Tyvj 1729 文艺平衡树(非旋treap)
传送门 经典的平衡树问题,之前已经用splay写过一次了,今天我突发奇想,写了一发非旋treap的版本,发现挺好写的(虽然跑不过splay). 代码: #include<bits/stdc++. ...
- 2018.07.24 loj#107. 维护全序集(非旋treap)
传送门 就是普通平衡树,可以拿来练非旋treap" role="presentation" style="position: relative;"&g ...
- 2018.07.06 BZOJ 1588: HNOI2002营业额统计(非旋treap)
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MB Description 营业额统计 Tiger最近被公司升任为营业部经理,他上 ...
- [模板] 平衡树: Splay, 非旋Treap, 替罪羊树
简介 二叉搜索树, 可以维护一个集合/序列, 同时维护节点的 \(size\), 因此可以支持 insert(v), delete(v), kth(p,k), rank(v)等操作. 另外, prev ...
- 2081.09.22 Kuma(非旋treap)
描述 有N张卡片,编号从0到n-1, 刚开始从0到n-1按顺序排好. 现有一个操作, 对于p. l,表示从第p张卡片之后的l张卡片拿到 最前面. 例如n=7的时候, 刚开始卡片序列为0 1 2 3 4 ...
- 非旋Treap及其可持久化
平衡树这种东西,我只会splay.splay比较好理解,并且好打,操作方便. 我以前学过SBT,但并不是很理解,所以就忘了怎么打了. 许多用平衡树的问题其实可以用线段树来解决,我们真正打平衡树的时候一 ...
随机推荐
- 23.OGNL与ValueStack(VS)-调用普通类的构造方法
转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html 建立一个新的类:Student,在此省略代码. 然后在loginSuc.js ...
- 从底层谈WebGIS 原理设计与实现(四):WebGIS中通过行列号来换算出多种瓦片的URL 之离线地图
从底层谈WebGIS 原理设计与实现(四):WebGIS中通过行列号来换算出多种瓦片的URL 之离线地图 作者:naaoveGI… 文章来源:naaoveGIS 点击数:1759 更 ...
- css兼容性记录
* , ie6,ie7可以识别: _和- , ie6可以识别: !important ,表示高优先级,ie7及以上,firefox都支持,ie6认识带!important的样式属性, ...
- Python Env
简介: 记录 CentOS 6.x Python 环境的安装步骤. 一.安装依赖包 shell > yum -y install epel-release shell > yum -y i ...
- python语法学习之函数、类、模块
Python中通过使用类(class)和对象(object)来实现面向对象(object-oriented programming,简称OOP)的编程. 面向对象编程的最主要目的是提高程序的重复使用性 ...
- Null value was assigned to a property of primitive type setter of"原因及解决方法
在action请求数据的过程中报出"Null value was assigned to a property of primitive type setter of"错误,搜索之 ...
- neo4j 学习-1
Neo4j 子句 ```MATCH (:Person { name: 'an' })-[r]->(:Persion) RETURN type(r) // 返回关系的类型 如:r 就是 'KNOW ...
- Dotfuscator Professional Edition获取代码发布和混淆代码
1 Dotfuscator Professional Edition 4.9 破解版 下载地址:http://www.pc0359.cn/downinfo/39815.html 备份地址:C:\D\9 ...
- mac下将根目录/更改组到普通用户,导致sudo不能用
背景:这是个很愚蠢的故事,我更改了根目录下所有文件的拥有者为普通用户[chown -R xxx / ].结果sudo/su命令都不能用了…… 问题:一旦用sudo命令或su命令就提示: sudo: ...
- tag-SMASS-1
SMASS 是在vasp的DFTMD中决定着系综的类型,在手册中给出的该参数具体信息如下: SMASS = -3 | -2 | -1 | [real] ≥ 0 Default: SMASS = -3 ...