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值,而这个值没 ...
随机推荐
- 54. Spiral Matrix(剑指offer 19)
Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral or ...
- awk命令学习(1)
awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各 ...
- 详解tween.js 中文使用指南
补间(动画)是一个概念,允许你以平滑的方式更改对象的属性.你只需告诉它哪些属性要更改,当补间结束运行时它们应该具有哪些最终值,以及这需要多长时间,补间引擎将负责计算从起始点到结束点的值. 例如,pos ...
- awk和sed
在正则表达式那章有两个比较好用的命令sed 和awk awk 是按指定分隔符分隔,默认空白键,第一个为$1,第二个为$2... 命令: FS分隔符
- android使用ARouter跳转activity(阿里巴巴开源的)
android使用ARouter跳转activity(阿里巴巴开源的) 使用ARouter方式,点击按钮跳转到其他activitypublic void buyOrSell(String str){ ...
- Python+OpenCV图像处理(二)——打印图片属性、设置图片存储路径、电脑摄像头的调取和显示
一. 打印图片属性.设置图片存储路径 代码如下: #打印图片的属性.保存图片位置 import cv2 as cv import numpy as np #numpy是一个开源的Python科学计算库 ...
- mergesort_arithmetic_python
def merge(a, b): c = [] h = j = 0 while j < len(a) and h < len(b): if a[j] < b[h]: c.append ...
- Python进阶【第七篇】文件处理
一.文件操作 在Python中,文件读写是最常见的操作.对文件的操作为: #1. 打开文件,得到文件句柄并赋值给一个变量 f=open('a.txt','r',encoding='utf-8') #默 ...
- Always an integer UVALive - 4119
题目很简单,就是求表达式(P/D)的结果是不是整数.其中P是一个整系数的多项式,D是一个正整数. 把1-k(最高次)+1都试一次就好了.结论可以总结归纳得到.(k取 0, 1, 2 .... 的情况推 ...
- Android 新老两代 Camera API 大起底
https://blog.csdn.net/Byeweiyang/article/details/80515192 0.背景简介 最近有一部分相机相关的需求,专注于对拍摄的照片.视频的噪点.色温.明暗 ...