bzoj1251权限题

题目点这里,你懂得

直接上板子,这个要好好体会

操作是最经典的。

 #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区间翻转区间最值与区间修改)的更多相关文章

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

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

  2. 【poj1901-求区间第k大值(带修改)】树状数组套主席树

    901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 7025  Solved: 2925[Sub ...

  3. CODEVS 4655 序列终结者-splay(区间更新、区间翻转、区间最值)

    4655 序列终结者  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master 题解       题目描述 Description 网上有许多题,就是给定一个序列,要 ...

  4. splay区间翻转

    原题P3391 [模板]文艺平衡树(Splay) 题目背景 这是一道经典的Splay模板题——文艺平衡树. 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: ...

  5. hdu-1890-Robotic Sort splay区间翻转

    题意: 依次找第i大的数下标pos[i],然后将区间[i,pos[i]]翻转 分析: splay树区间翻转 // File Name: ACM/HDU/1890.cpp // Author: Zlbi ...

  6. bzoj3223 Tyvj 1729 文艺平衡树(Splay Tree+区间翻转)

    3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2202  Solved: 1226[Submit][Sta ...

  7. hdu1890 splay维护区间翻转

    这题的建模有点不太一样,是按结点横坐标赋予键值的 同时每次rotate和splay时都要注意下往上往下更新 /* 先建立好splay tree,将结点按num/输入顺序排序,遍历时每次将当前结点提到根 ...

  8. BZOJ 3223: Tyvj 1729 文艺平衡树-Splay树(区间翻转)模板题

    3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 6881  Solved: 4213[Submit][Sta ...

  9. bzoj 3223 文艺平衡树 splay 区间翻转

    Tyvj 1728 普通平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 17715  Solved: 7769[Submit][Status][ ...

  10. BZOJ 3223 Splay区间翻转

    思路: 区间翻转的裸题 终于tm理解splay了-- //By SiriusRen #include <cstdio> #include <cstring> #include ...

随机推荐

  1. Cenos7 学习笔记

    一.nmtui nmtui——Text User Interface for controlling NetworkManager,这是一个NetworkManager服务的网卡接口配置工具,能实现在 ...

  2. mybatis第二天01

    MyBatis第二天01 1.高级结果映射 1.1根据视频案例,分析表之间的关系 数据模型分析 1. 明确每张表存储的信息 2. 明确每张表中关键字段(主键.外键.非空) 3. 明确数据库中表与表之间 ...

  3. AVR单片机丢固件原因分析和解决方案

    一.硬件方面 除了下面列举的方面,还需要评估下其他措施. 1.电源因素,禁干扰. 只要用廉价劣质的开关电源,不管哪个单片机,都存在EEPROM丢数据和单片机程序丢失的情况. 1.转接板走线,直接接到了 ...

  4. Python环境搭建(win)——Pycharm(破解+汉化)

    Pycharm搭建方法(破解+汉化): 本文以pycharm2019.2为例 写在前面:有能力的朋友,希望大家支持正版. IDE是集成开发环境 “Integrated Development Envi ...

  5. ANDROID开发之问题积累及解决方案(四)

    首先贴出问题类型: 程序无法启动,查看logcat,提示如下信息: W/dalvikvm(679): PR_CAPBSET_DROP 32 failed: Invalid argument. Plea ...

  6. cc.formatStr()用法

    cc.formatStr() 第一个变量为含有 %s 或 %d 的字符串 后面依次为%s或%d对应的内容

  7. P1010 幂次方(分治)

    https://www.luogu.com.cn/problem/P1010 刚刚看到这个题时,有点懵,如果说这是个数学题 比如说7,应该先求出7 = 4 + 2 + 1; 即先分解出里面应该有最多的 ...

  8. 【网页浏览】国内伪P站搜图网站

    蛮好用的国内p站搜图网站(伪p站) 传送链接

  9. 【PAT甲级】1116 Come on! Let's C (20分)

    题意: 输入一个正整数N(<=10000),接着依次输入N个学生的ID.输入一个正整数Q,接着询问Q次,每次输入一个学生的ID,如果这个学生的ID不出现在之前的排行榜上输出Are you kid ...

  10. go 语言实现栈原理

    package main import "fmt" type StackNode struct { Data interface{} //数据 Next *StackNode // ...