splay(1区间翻转区间最值与区间修改)
直接上板子,这个要好好体会
操作是最经典的。
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <vector>
#include <cmath>
#include <queue>
#include <map>
#include <set>
using namespace std;
#define file(x) freopen(x".in","r",stdin),freopen(x".out","w",stdout)
inline void read(int &ans) {
ans=;char x=getchar();bool f=;
while(x<''||x>'') {if(x=='-')f=;x=getchar();}
while(x>=''&&x<='')ans=ans*+x-'',x=getchar();
f?ans=-ans:;
}
const int MAXN=1e5+;
const int INF=2e9;
struct splay_tree{
struct node{
int val,max,add,size,son[];
bool rev;//区间是否翻转
void init(int _val){
val=max=_val ,size=;
add=rev=son[]=son[]=;
}
}T[MAXN];
int fa[MAXN],root; void pushup(int x){
T[x].max=T[x].val ,T[x].size=;
for(int k=;k<;k++)
if(T[x].son[k]){
T[x].max=max(T[x].max,T[T[x].son[k]].max);
T[x].size+=T[T[x].son[k]].size;
}
} void pushdown(int x){
if(x==)return;
if(T[x].add){
for(int k=;k<;k++)
if(T[x].son[k]){
T[T[x].son[k]].val+=T[x].add;
T[T[x].son[k]].max+=T[x].add;
T[T[x].son[k]].add+=T[x].add;
}
T[x].add=;
}
if(T[x].rev){
for(int k=;k<;k++)
if(T[x].son[k]) T[T[x].son[k]].rev^=;
swap(T[x].son[],T[x].son[]);
T[x].rev=;
}
} void rotate(int x,int k){
int y=fa[x] ,z=fa[y];
T[y].son[!k]=T[x].son[k] ,fa[T[x].son[k]]=y;
T[x].son[k]=y ,fa[y]=x;
T[z].son[T[z].son[]==y]=x ,fa[x]=z;
pushup(y);
} void splay(int x,int goal){
if(x==goal)return;
while(fa[x]!=goal){
int y=fa[x] ,z=fa[y];
pushdown(z) ,pushdown(y) ,pushdown(x);
int rx=T[y].son[]==x ,ry=T[z].son[]==y;
if(z==goal)rotate(x,rx);
else{
if(rx==ry)rotate(y,ry);
else rotate(x,rx);
rotate(x,ry);
}
}
pushup(x);
if(goal==)root=x;
} int select(int p){
int u=root;
pushdown(u);
while(p!=T[T[u].son[]].size){
if(p<T[T[u].son[]].size)u=T[u].son[];
else{
p-=T[T[u].son[]].size+;
u=T[u].son[];
}
pushdown(u);
}
return u;
} void updata(int L,int R,int val){
int u=select(L-) ,v=select(R+);
splay(u,);
splay(v,u);
T[T[v].son[]].max+=val;
T[T[v].son[]].val+=val;
T[T[v].son[]].add+=val;
} void reverse(int l,int r){
int u=select(l-) ,v=select(r+);
splay(u,);
splay(v,u);
T[T[v].son[]].rev^=;
} int query(int l,int r){
int u=select(l-) ,v=select(r+);
splay(u,);
splay(v,u);
return T[T[v].son[]].max;
} int build(int l,int r){
if(l>r) return ;
if(l==r) return l;
int mid=(l+r)>> ,ls, rs;
ls=T[mid].son[]=build(l,mid-);
rs=T[mid].son[]=build(mid+,r);
fa[ls]=fa[rs]=mid;
pushup(mid);
return mid;
} void init(int n){
T[].init(-INF) ,T[].init(-INF) ,T[n+].init(-INF);
for(int i=;i<=n+;i++)T[i].init();
root=build(,n+) ,fa[root]=;
fa[]= ,T[].son[]=root ,T[].size=;
}
}; splay_tree bzoj1251;
int n,m,a,b,c,d;
int main() {
read(n),read(m);
bzoj1251.init(n);
for(int i=;i<m;i++){
read(a),read(b),read(c);
if(a==)read(d),bzoj1251.updata(b,c,d);
else if(a==)bzoj1251.reverse(b,c);
else printf("%d\n",bzoj1251.query(b,c));
}
return ;
}
splay(1区间翻转区间最值与区间修改)的更多相关文章
- bzoj 1251序列终结者 splay 区间翻转,最值,区间更新
序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 4594 Solved: 1939[Submit][Status][Discuss] De ...
- 【poj1901-求区间第k大值(带修改)】树状数组套主席树
901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 7025 Solved: 2925[Sub ...
- CODEVS 4655 序列终结者-splay(区间更新、区间翻转、区间最值)
4655 序列终结者 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题解 题目描述 Description 网上有许多题,就是给定一个序列,要 ...
- splay区间翻转
原题P3391 [模板]文艺平衡树(Splay) 题目背景 这是一道经典的Splay模板题——文艺平衡树. 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: ...
- hdu-1890-Robotic Sort splay区间翻转
题意: 依次找第i大的数下标pos[i],然后将区间[i,pos[i]]翻转 分析: splay树区间翻转 // File Name: ACM/HDU/1890.cpp // Author: Zlbi ...
- bzoj3223 Tyvj 1729 文艺平衡树(Splay Tree+区间翻转)
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2202 Solved: 1226[Submit][Sta ...
- hdu1890 splay维护区间翻转
这题的建模有点不太一样,是按结点横坐标赋予键值的 同时每次rotate和splay时都要注意下往上往下更新 /* 先建立好splay tree,将结点按num/输入顺序排序,遍历时每次将当前结点提到根 ...
- BZOJ 3223: Tyvj 1729 文艺平衡树-Splay树(区间翻转)模板题
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 6881 Solved: 4213[Submit][Sta ...
- bzoj 3223 文艺平衡树 splay 区间翻转
Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 17715 Solved: 7769[Submit][Status][ ...
- BZOJ 3223 Splay区间翻转
思路: 区间翻转的裸题 终于tm理解splay了-- //By SiriusRen #include <cstdio> #include <cstring> #include ...
随机推荐
- 统计redis大key信息(前topN)
相关包下载链接 https://github.com/sripathikrishnan/redis-rdb-tools/releaseshttps://pypi.org/project/python- ...
- Java中8进制数和16进制数的表示方法
由于数据在计算机中的表示,最终以二进制的形式存在,所以有时候使用二进制,可以更直观地解决问题. 但,二进制数太长了.比如int 类型占用4个字节,32位.比如100,用int类型的二进制数表达将 ...
- Appium+python自动化-元素定位uiautomatorviewer的使用
前言 环境搭建好了,下一步元素定位,元素定位本篇主要介绍如何使用uiautomatorviewer,通过定位到页面上的元素,然后进行相应的点击等操作. uiautomatorviewer是androi ...
- python Threading模块源码解析
查看源码: 这是一个线程控制的类,这个类可以被子类化(继承)在一定的条件限制下,这里有两种方式去明确活动:第一通过传入一个callable 对象也就是调用对象,一种是通过重写这个Thread类的run ...
- 159.SQL注入的实现和防御措施
sql注入: 所谓sql注入,就是通过把sql命令插入到表单中或页面请求的查询字符串中,最终达到欺骗服务器执行恶意的sql命令.具体来说,它是利用现有的应用程序,将(恶意的)sql命令注入到后台数据库 ...
- python笔记-01
Python环境安装 1.Windows下一键环境安装包 2.Python2.X与Python3.X 什么是代码? 代码是现实世界事物在计算机世界中的映射 什么是写代码? 写代码是将现实世界中的事物用 ...
- Java 并发核心机制
目录 一.J.U.C 简介 二.synchronized 三.volatile 四.CAS 五.ThreadLocal 参考资料
- mybatis(二):缘由
本是Apache的一个开源项目iBatis 2010年,iBatis由Apache Software Foundation(软件基金会)迁移到了Google Code(代码托管平台),并改名为MyBa ...
- JavaDay1(下)
Java learning_Day1(上) 正式开始JavaSE的基础学习 本人学习视频用的是马士兵的,也在这里献上 <链接:https://pan.baidu.com/s/1qKNGJNh0G ...
- bugku sql2
sql注入2 200 http://123.206.87.240:8007/web2/ 全都tm过滤了绝望吗? 提示 !,!=,=,+,-,^,%