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. linux--介绍和指令练习

    Linux Linux就是个操作系统:它和Windows XP.Windows7.8.10什么的一样就是一个操作系统而已! Linux能干什么:能当服务器,在服务器上安装者各种企业应用.服务. 比如: ...

  2. 牛客练习赛53 C题bitset

    题目链接https://ac.nowcoder.com/acm/contest/1114/C #include<bits/stdc++.h> using namespace std; #d ...

  3. python接口自动化之pytest环境准备与入门(五)

    安装的pytest版本应该与安装的python版本对应,不然会有问题 (我的环境是python3.6与pytest4.5.0) 1.安装pytest pip install pytest==4.5.0 ...

  4. layer弹出层右上角的关闭按钮怎么没有显示

    问题描述:layer弹出层右上角的关闭按钮怎么没有显示,但鼠标移上去又可以点击 解决方式: 这是因为样式中需要一个图标,你的项目中缺少.解决如下:1.下载图标:http://www-x-zi-han- ...

  5. ALSA lib-io plugin

    https://www.alsa-project.org/alsa-doc/alsa-lib/pcm_external_plugins.html External Plugin: I/O Plugin ...

  6. nginx配置长连接(ajax60秒请求超时)

    个人博客 地址:http://www.wenhaofan.com/article/20180911150337 1.在使用ajax做轮训的时候前台发出的ajax请求总是会在60秒之后返回405超时响应 ...

  7. webpack 之loader

      webpack的作用: 是 用来处理我们写的js代码.并且会自动处理js之间相关的依赖. 但是,开发中我们不仅仅有基本的js代码处理,还需要加载css,图片,也包括一些高级的 将ES6转成ES5代 ...

  8. 为什么 K8s 在阿里能成功(转)

    为什么 K8s 在阿里能成功?| 问底中国 IT 技术演进   作者:曾凡松 阿里云云原生应用平台高级技术专家张振 阿里云云原生应用平台高级技术专家 导读:本文描述了阿里巴巴在容器管理领域的技术演进历 ...

  9. 使用TensorFlow训练模型的基本流程

    本文已在公众号机器视觉与算法建模发布,转载请联系我. 使用TensorFlow的基本流程 本篇文章将介绍使用tensorflow的训练模型的基本流程,包括制作读取TFRecord,训练和保存模型,读取 ...

  10. JavaScript的严格检查模式

    JavaScript的严格检查模式 前提:IDEA设置为ECMAScript 6语法. 'use strict':严格检查模式,用来预防JS的随意性导致的问题. 比如:直接 i=1;这样定义成了全局变 ...