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值,而这个值没 ...
随机推荐
- 安装oracle经验
1.使用database configuration assistant配置和创建数据库 2.使用net manager配置监听 3.使用netconfiguration assistant配置服务
- eclipse设置字体_字符编码_快捷键
eclipse设置字体.字符编码.快捷键 1.设置字体: preferences->general->appearnce->colors and fonts-->basic-- ...
- Quick-Cocos2d-x文件结构分析
在上一章我们讲过了Quick-Cocos2d-x中的环境搭建,这章我们分析下quick中的文件结构吧!打开quick的文件夹,可以看到如下的这些目录和文件: bin:存放各种与引擎相关的脚本 comp ...
- css中块级元素、内联元素(行内元素、内嵌元素)
Block element 块级元素 顾名思义就是以块显示的元素,高度宽度都是可以设置的.比如我们常用 的<div>.<p>.<ul>默认状态下都是属于块级元 ...
- loadRunner手动关联, web_reg_save_param_regexp()函数正则匹配字符,赋值给变量
loadRunner写脚本实现登录机票网站,手动关联,获取页面源码中特定字符 手动关联,就是通过函数获取某个步骤生成的字符,赋值给一个变量,这个变量可以作为接下来某个步骤的输入, 以便这个脚本能够在存 ...
- 【JavaScript 6连载】五、继承的概念
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- C/C++编译、链接、运行的基础知识
0.C/C++从源文件在编译器的作用下先编译成.s的汇编,然后在汇编器的作用下变成.o的可重定向目标文件,然后在链接器的作用下变成可执行文件 1.在项目中设置的编译寻找目录中的.h文件(一般就是inc ...
- 【web前端】移动端控制台插件,手机端页面查看相关页面控制台信息
一般调试手机端页面时,基本是在PC端使用手机模式进行断点或console调试.或查看有用的控制台信息的,但依旧有部分功能无法在PC端调试,经常需要使用alert进行断点,然后在手机端看效果,但是这样并 ...
- sqlalchemy 多对多关系
# -*- coding: utf-8 -*- from sqlalchemy import Column, String, create_engine,ForeignKey,Text,Integer ...
- JDK源码之LinkedHashSet
LinkedHashSet是HashSet和LinkList结合产生的集合,集合中的元素互不相同,且元素采用双向链表进行连接. 1.定义 LinkedHashSet继承了HashSet并且实现了Set ...