链接

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

  1. BZOJ 1251 序列终结者(Splay)

    题目大意 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术 ...

  2. BZOJ 1251: 序列终结者 [splay]

    1251: 序列终结者 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 3778  Solved: 1583[Submit][Status][Discu ...

  3. BZOJ 1251: 序列终结者

    1251: 序列终结者 Time Limit: 20 Sec  Memory Limit: 162 MB Submit: 3773  Solved: 1579 [Submit][Status][Dis ...

  4. bzoj 1251序列终结者 splay 区间翻转,最值,区间更新

    序列终结者 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 4594  Solved: 1939[Submit][Status][Discuss] De ...

  5. 【BZOJ】1251: 序列终结者(splay)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1251 不行..为什么写个splay老是犯逗,这次又是null的mx没有赋值-maxlongint.. ...

  6. 1251. 序列终结者【平衡树-splay】

    Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这 ...

  7. 【BZOJ】1251: 序列终结者

    [题意]给定含有n个0的的数列. 1.区间加值 2.区间翻转 3.区间求最大值 [算法]平衡树(fhq-treap) 需要特别注意的是: 1.使0点对全局无影响并全程保持(例如求max,t[0].mx ...

  8. 【bzoj1251】序列终结者(伸展树)

    [bzoj1251]序列终结者(伸展树) Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我 ...

  9. 【BZOJ】【1251】序列终结者

    Splay 还是splay序列维护,这题我WA了的原因是:在Push_up的时候,当前子树的max我是直接取的L.R和v[x]的最大值,但是如果没有左/右儿子,默认是会访问0号结点的mx值,而这个值没 ...

随机推荐

  1. pyinstaller将python脚本生成exe

    一.下载pyinstaller 二.生成exe 下载pyinstaller 1.在C:\python27\Scripts目录下打开cmd界面,执行命令:pip install PyInstaller ...

  2. 2GT PULLEYS 同步齒輪 設計規格

    2GT PULLEYS 同步齒輪 設計規格 [資料來源:http://www.jigang.com.tw/zh/product_item/64] 我的20齒 2GT模型 張貼者: 陳亮宇於 上午11: ...

  3. CSS小知识-----前缀-moz-、-ms-、-webkit-,-o-分别代表的意思

    这种方式在业界上统称:识别码.前缀 -ms-代表[ie]内核识别码 -moz-代表火狐[firefox]内核识别码 -webkit-代表谷歌[chrome]/苹果[safari]内核识别码 -o-代表 ...

  4. MySql 查询表中字段的数据类型

    [1]MySQL中查询某表中字段的数据类型 (1)DESC 表名: (2)DESCRIBE 表名: (3)SHOW COLUMNS FROM 表名: 应用示例: DESC cfg_acct_free_ ...

  5. 20165215 实验三 敏捷开发与XP实践

    20165215 实验三 敏捷开发与XP实践 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:张家佳 学号:20165215 指导教师:娄嘉鹏 实验日期:2018年4月28日 实验时 ...

  6. tft屏图像显示也成功完成

    2010-04-30 14:18:00 tft屏图像显示也成功完成. 其实有了刷屏的经验,图像显示就很简单. void address_set(uint x1,uint y1,uint x2,uint ...

  7. [转载]ViewPort <meta>标记

    ViewPort <meta>标记用于指定用户是否可以缩放Web页面,如果可以,那么缩放到的最大和最小缩放比例是什么.使用 ViewPort <meta>标记还表示文档针对移动 ...

  8. GoldenGate 12.2抽取Oracle 12c多租户配置过程

    linux下安装12c 重启linux之后,dbca PDB/CDB使用 SQL> select instance_name from v$instance; INSTANCE_NAME --- ...

  9. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:

    ### Error updating database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You h ...

  10. ionic + angular + cordova, 打造专属自己的App!

    ionic 学习地址:http://ionicframework.com/ ionic 好处: ionic serve --lab  预览平台间的差异化 sass                  提 ...