一道模板题,一直没发现自己的快速读入读不了负数,我竟然能活到现在真是万幸。

 #include <iostream>
#include <cstdio>
#define inf -0x7fffffff
#define N 50010
using namespace std;
struct SplayNode
{
SplayNode();
SplayNode *fa,*ch[];
//SplayNode(int x);
int data,maxn,size,add;
bool rev;
void push();
bool chr() {return this==fa->ch[];}
void updata()
{
size=ch[]->size+ch[]->size+;
maxn=max(max(ch[]->maxn,ch[]->maxn),data);
}
void setc(SplayNode *x,int t) {this->ch[t]=x; x->fa=this;}
}*null;
SplayNode::SplayNode() {fa=ch[]=ch[]=null; rev=;data=add=size=; maxn=inf;}
void SplayNode::push()
{
if (rev)
{
if (ch[]!=null) ch[]->rev^=;
if (ch[]!=null) ch[]->rev^=;
swap(ch[],ch[]);
rev=;
}
if (add!=)
{
if (ch[]!=null)
{
ch[]->add+=add;
ch[]->maxn+=add;
ch[]->data+=add;
}
if (ch[]!=null)
{
ch[]->add+=add;
ch[]->maxn+=add;
ch[]->data+=add;
}
add=;
}
}
int n,m;
//inline int read() {int ans=0; char c; while ((c=getchar())=='\r' || c=='\n' || c==' '); ans=c-'0'; while (isdigit(c=getchar())) ans=ans*10+c-'0'; return ans;}
namespace Splay
{
SplayNode *Root;
SplayNode pool[N];
int poolnum=;
SplayNode *NewNode()
{
poolnum++;
pool[poolnum]=SplayNode();
return &pool[poolnum];
}
SplayNode *BuildTree(int l,int r)
{
if (l>r) return null;
SplayNode *re=NewNode();
int mid=(l+r)>>;
re->data=;
re->ch[]=BuildTree(l,mid-);
re->ch[]=BuildTree(mid+,r);
re->ch[]->fa=re;
re->ch[]->fa=re;
re->updata();
return re;
}
void rotate(SplayNode *x)
{
SplayNode *r=x->fa;
if (x==null || r==null) return;
int t=x->chr();
x->push(); r->push();
if (r->fa==null) x->fa=r->fa,Root=x;
else r->fa->setc(x,r->chr());
r->setc(x->ch[t^],t);
x->setc(r,!t);
r->updata();
x->updata();
}
void splay(SplayNode *x,SplayNode *y)
{
for (;x->fa!=y;rotate(x))
if (x->fa->fa!=y)
if (x->chr()==x->fa->chr()) rotate(x->fa);
else rotate(x);
}
SplayNode *Kth(int k)
{
SplayNode *r=Root;
while (r!=null)
{
r->push();
if (k<=r->ch[]->size) r=r->ch[];
else if (k==r->ch[]->size+) return r;
else
{
k-=r->ch[]->size+;
r=r->ch[];
}
}
return null;
}
void reverse(int l,int r)
{
SplayNode *p=Kth(l);
SplayNode *s=Kth(r+);
p->push();
splay(p,null);
s->push();
splay(s,p);
s->ch[]->rev^=;
}
void Add(int l,int r,int v)
{
SplayNode *p=Kth(l);
SplayNode *s=Kth(r+);
p->push();
splay(p,null);
s->push();
splay(s,p);
s->ch[]->add+=v;
s->ch[]->data+=v;
s->ch[]->maxn+=v;
}
void query(int l,int r)
{
SplayNode *p=Kth(l);
SplayNode *s=Kth(r+);
p->push();
splay(p,null);
s->push();
splay(s,p);
printf("%d\n",s->ch[]->maxn);
}
}
void init() {null=Splay::NewNode(); *null=SplayNode(); Splay::Root=Splay::BuildTree(,n+);}
int main()
{
scanf("%d%d",&n,&m);
init();
//for (int i=1;i<=n;i++) a[i]=read();
//Splay::BuildTree(1,n);
for (int i=;i<=m;i++)
{
int temp,x,y;
scanf("%d%d%d",&temp,&x,&y);
//temp=read(); x=read(); y=read();
if (temp==)
{
int v;
scanf("%d",&v);
Splay::Add(x,y,v);
}
if (temp==) Splay::reverse(x,y);
if (temp==) Splay::query(x,y);
}
return ;
}

Description

网上有许多题,就是给定一个序列,要你支持几种操作:A、B、C、D。一看另一道题,又是一个序列 要支持几种操作:D、C、B、A。尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术含量……这样 我也出一道题,我出这一道的目的是为了让大家以后做这种题目有一个“库”可以依靠,没有什么其他的意思。这道题目 就叫序列终结者吧。 【问题描述】 给定一个长度为N的序列,每个序列的元素是一个整数(废话)。要支持以下三种操作: 1. 将[L,R]这个区间内的所有数加上V。 2. 将[L,R]这个区间翻转,比如1 2 3 4变成4 3 2 1。 3. 求[L,R]这个区间中的最大值。 最开始所有元素都是0。

Input

第一行两个整数N,M。M为操作个数。 以下M行,每行最多四个整数,依次为K,L,R,V。K表示是第几种操作,如果不是第1种操作则K后面只有两个数。

Output

对于每个第3种操作,给出正确的回答。

Sample Input

4 4
1 1 3 2
1 2 4 -1
2 1 3
3 2 4

Sample Output

2
【数据范围】
N<=50000,M<=100000。

HINT

 

Source

 

【BZOJ1251】序列终结者 Splay的更多相关文章

  1. [bzoj1251]序列终结者——splay

    题目大意 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技 ...

  2. bzoj1251 序列终结者(splay)

    人生第一发splay,写得巨丑,最后忘记了push_down以后要将子节点maintain 9k代码不忍直视 #define NDEBUG #include<cstdio> #includ ...

  3. [BZOJ1251]序列终结者

    [BZOJ1251]序列终结者 试题描述 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题 ...

  4. bzoj1251 序列终结者(Splay Tree+懒惰标记)

    Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这 ...

  5. BZOJ1251 序列终结者(Splay平衡树)(占位)

    网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术含量…… ...

  6. [bzoj1251]序列终结者_splay

    序列终结者 bzoj-1251 题目大意:给定一个长度为n的正整数序列,支持区间加,区间反转,查询区间最大值.所有元素开始都是0. 注释:$1\le n\le 5\cdot 10^4$,操作个数不多于 ...

  7. BZOJ 1251: 序列终结者 [splay]

    1251: 序列终结者 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 3778  Solved: 1583[Submit][Status][Discu ...

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

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

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

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

随机推荐

  1. shell中的条件判断、参数以及变量替换

    文章转自: http://www.cnblogs.com/maxupeng/archive/2011/07/02/2096551.html 一.test命令 test命令是shell内部命令,它计算作 ...

  2. php5 数据类型

    一.PHP主要有一下几种数据类型 String(字符串), Integer(整型), Float(浮点型), Boolean(布尔型), Array(数组), Object(对象), NULL(空值) ...

  3. unity3D游戏-WorldFight

    计划写一个2D策略类的游戏,玩法类似炉石传说,以收集卡牌为主,不同的地方在于战斗方式类似棋类游戏,而且还有一个技能系统作为补充. ---更新(2015.7.13) v2.0.1更新: 添加了基本AI ...

  4. 关于当传过来的值转换成string类型报错的问题

    有时候直接写 string str=request.param["str"].tostring;会报错,是因为接受到的值可能是空的 这个时候就可以这样写 string _actio ...

  5. PHP变量作用域详解(二)

    学过C的人用PHP的时候一般会相当顺手,而且感到PHP太方便太轻松.但在变量作用域这方面却与C有不同的地方,搞不好会相当郁闷,就找不到错误所在.昨晚就与到这么一个问题,是全局变量在函数中的问题.今天搜 ...

  6. MySQL Cluster 数据分布(分区、分组)

    数据分布 1.MySQL Cluster自动分区数据表(也可能使用用户自定义分区),将数据分布到分区中: 2.一个数据表被划分到多个Data Node分区中,数据在分区中被”striped”: 3.主 ...

  7. 【Android学习】解决Eclipse AVD打开慢的问题

    1.创建的时候勾选“Snapshot” 2.之后Start时候勾选对应的.

  8. install alilang

    $sudo dpkg -i alilang.deb $ sudo alilang

  9. JavaScript访问ab页面定时跳转代码

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. iOS 多个异步网络请求全部返回后再执行具体逻辑的方法

    对于dispatch多个异步操作后的同步方法,以前只看过dispatch_group_async,看看这个方法的说明: * @discussion * Submits a block to a dis ...