#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cstring>
#include<stack>
#define Tp Treap*
#define DTp pair<Tp,Tp>
#define ft first
#define sc second
#define INF 0x7f7f7f7f
#define MAXN 500000+10
using namespace std;
int n,m;
int a[MAXN];
struct Treap{
Tp l;Tp r;
int key,fix;
int size,sum,lx,rx,mx,tag;
};
Tp root;
stack<Tp> s;
Tp new_node(int v){
Tp ret;
if(s.empty())ret=new Treap;
else ret=s.top(),s.pop();
ret->l=ret->r=NULL;
ret->key=ret->sum=v;
ret->lx=ret->rx=ret->mx=v;
ret->tag=-INF;
ret->size=,ret->fix=rand();
return ret;
}
int Size(Tp A){return (A?A->size:);}
int Sum(Tp A){return (A?A->sum:);}
int Lx(Tp A){return (A?A->lx:-INF);}
int Rx(Tp A){return (A?A->rx:-INF);}
int Mx(Tp A){return (A?A->mx:-INF);}
void upd(Tp A){
A->size=Size(A->l)+Size(A->r)+;
A->sum=Sum(A->l)+Sum(A->r)+A->key;
A->mx=max(max(Mx(A->l),Mx(A->r)),A->key+max(Rx(A->l),)+max(Lx(A->r),));
A->lx=max(Lx(A->l),Sum(A->l)+A->key+max(Lx(A->r),));
A->rx=max(Rx(A->r),Sum(A->r)+A->key+max(Rx(A->l),));
}
void Print(Tp A){
if(!A)return;
// pushdown(A);
// printf("key=%d,size=%d,sum=%d,lx=%d,rx=%d,mx=%d\n",A->key,A->size,A->sum,A->lx,A->rx,A->mx);
Print(A->l);
printf("%d ",A->key);
Print(A->r);
if(A==root)printf("\n");
}
void update(Tp A,int x){
if(!A||-INF==x)return;
if(x!=INF){
A->tag=x;
A->key=x;
A->sum=x*A->size;
A->mx=A->lx=A->rx=(x>?A->sum:x);
}
else{
if(A->tag!=INF&&A->tag!=-INF)return;
swap(A->l,A->r);
swap(A->lx,A->rx);
A->tag=-A->tag;
}
}
void pushdown(Tp A){
update(A->l,A->tag);
update(A->r,A->tag);
A->tag=-INF;
}
Tp build(int L,int R){
if(L>R)return NULL;
int mid=(L+R)>>;
Tp ret=new_node(a[mid]);
ret->l=build(L,mid-);
ret->r=build(mid+,R);
upd(ret);
return ret;
}
Tp Merge(Tp A,Tp B){
if(!A)return B;
if(!B)return A;
if(A->fix<B->fix){
pushdown(A);
A->r=Merge(A->r,B);
upd(A);
return A;
}
else{
pushdown(B);
B->l=Merge(A,B->l);
upd(B);
return B;
}
}
DTp Split(Tp A,int k){
if(!A)return DTp(NULL,NULL);
pushdown(A);
DTp y;
if(Size(A->l)>=k){
y=Split(A->l,k);
A->l=y.sc;
upd(A);
y.sc=A;
}
else{
y=Split(A->r,k-Size(A->l)-);
A->r=y.ft;
upd(A);
y.ft=A;
}
return y;
}
int pos,len;
void Insert(){
scanf("%d%d",&pos,&len);
for(int i=;i<=len;i++)scanf("%d",&a[i]);
DTp x=Split(root,pos);
root=Merge(x.ft,Merge(build(,len),x.sc));
}
void Del(Tp A){
if(!A)return;
s.push(A);
Del(A->l);
Del(A->r);
}
void Delete(){
scanf("%d%d",&pos,&len);
DTp x=Split(root,pos-);
DTp y=Split(x.sc,len);
Del(y.ft);
root=Merge(x.ft,y.sc);
}
void MakeSame(){
int v;
scanf("%d%d%d",&pos,&len,&v);
DTp x=Split(root,pos-);
DTp y=Split(x.sc,len);
update(y.ft,v);
root=Merge(x.ft,Merge(y.ft,y.sc));
}
void Rev(){
scanf("%d%d",&pos,&len);
DTp x=Split(root,pos-);
DTp y=Split(x.sc,len);
update(y.ft,INF);
root=Merge(x.ft,Merge(y.ft,y.sc));
}
int GetSum(){
scanf("%d%d",&pos,&len);
if(!len)return ;
DTp x=Split(root,pos-);
DTp y=Split(x.sc,len);
int ans=y.ft->sum;
root=Merge(x.ft,Merge(y.ft,y.sc));
return ans;
}
int MaxSum(){
return root->mx;
}
void init(){
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
root=build(,n);
}
void solve(){
char s[];
while(m--){
scanf("%s",s);
if('I'==s[])Insert();
else if('D'==s[])Delete();
else if('M'==s[]&&'E'==s[])MakeSame();
else if('R'==s[])Rev();
else if('G'==s[])printf("%d\n",GetSum());
else printf("%d\n",MaxSum());
}
}
int main()
{
// freopen("testdata.in.txt","r",stdin);
// freopen("my.out","w",stdout);
init();
solve();
return ;
}

洛谷P2042 [NOI2005]维护数列的更多相关文章

  1. 洛谷 P2042 [NOI2005]维护数列-Splay(插入 删除 修改 翻转 求和 最大的子序列)

    因为要讲座,随便写一下,等讲完有时间好好写一篇splay的博客. 先直接上题目然后贴代码,具体讲解都写代码里了. 参考的博客等的链接都贴代码里了,有空再好好写. P2042 [NOI2005]维护数列 ...

  2. 洛谷.2042.[NOI2005]维护数列(Splay)

    题目链接 2017.12.24 第一次写: 时间: 2316ms (1268ms) 空间: 19.42MB (19.5MB)(O2) 注:洛谷测的时间浮动比较大 /* 插入一段数:将这些数先单独建一棵 ...

  3. 【洛谷P2042】维护数列

    题目大意:维护一个序列,支持区间插入,区间删除,区间翻转,查询区间元素和,查询区间最大子段和操作. 题解:毒瘤题...QAQ打完这道题发现自己以前学了一个假的 Splay.. 对于区间操作,用 spl ...

  4. P2042 [NOI2005]维护数列 && Splay区间操作(四)

    到这里 \(A\) 了这题, \(Splay\) 就能算入好门了吧. 今天是个特殊的日子, \(NOI\) 出成绩, 大佬 \(Cu\) 不敢相信这一切这么快, 一下子机房就只剩我和 \(zrs\) ...

  5. P2042 [NOI2005]维护数列[splay或非旋treap·毒瘤题]

    P2042 [NOI2005]维护数列 数列区间和,最大子列和(必须不为空),支持翻转.修改值.插入删除. 练码力的题,很毒瘤.个人因为太菜了,对splay极其生疏,犯了大量错误,在此记录,望以后一定 ...

  6. Luogu P2042 [NOI2005]维护数列(平衡树)

    P2042 [NOI2005]维护数列 题意 题目描述 请写一个程序,要求维护一个数列,支持以下\(6\)种操作:(请注意,格式栏中的下划线'_'表示实际输入文件中的空格) 输入输出格式 输入格式: ...

  7. BZOJ 1500 Luogu P2042 [NOI2005] 维护数列 (Splay)

    手动博客搬家: 本文发表于20180825 00:34:49, 原地址https://blog.csdn.net/suncongbo/article/details/82027387 题目链接: (l ...

  8. Luogu P2042 [NOI2005]维护数列

    题目描述 请写一个程序,要求维护一个数列,支持以下 6 种操作:(请注意,格式栏 中的下划线' _ '表示实际输入文件中的空格) 输入输出格式 输入格式: 输入文件的第 1 行包含两个数 N 和 M, ...

  9. P2042 [NOI2005]维护数列

    思路 超级恶心的pushdown 昏天黑地的调 让我想起了我那前几个月的线段树2 错误 这恶心的一道题终于过了 太多错误,简直说不过来 pushup pushdown 主要就是这俩不太清晰,乱push ...

随机推荐

  1. 团队作业5-测试与发布(AIpha版本)

    对于已完成的项目我们进行了诸多测试,找到了少许bug,对着这些bug我们在改进的基础上提出了新的目标. 1,测试环境:个人笔记本.个人台式机.环境windows7.网络校园网加移动vpn,浏览器360 ...

  2. 关于第一次使用vue-cli

    前段时间终于终于可以用vue-cli,webpack做个企业站,记一下过程... 首先node.js,按照vue官网的步骤命令提示符走一波,网速原因,所以用的是淘宝镜像 cnpm # 全局安装 vue ...

  3. CentOS搭建Git服务器及权限管理

    声明:本教程,仅作为配置的记录,细节不展开,需要您有一点linux的命令基础,仅作为配置参考. 1. 系统环境 系统: Linux:CentOS 7.2 64位 由于CentOS已经内置了OpenSS ...

  4. JAVA_SE基础——54.异常

    异常的体系: ----------| Throwable  所以异常或者错误类的超类 --------------|Error  错误   错误一般是用于jvm或者是硬件引发的问题,所以我们一般不会通 ...

  5. web信息泄露注意事项

    1. 确保您的Web服务器不发送显示有关后端技术类型或版本信息的响应头. 2. 确保服务器打开的端口上运行的所有服务都不会显示有关其构建和版本的信息. 3. 确保所有目录的访问权限正确,保证不会让攻击 ...

  6. python+flask 分分钟完美解析阿里云日志

    拿到了自己阿里云服务器的日志,对其需要进行处理. class Read_Rizhi: def __init__(self,filename): self.filename=filename def o ...

  7. 机器学习中 K近邻法(knn)与k-means的区别

    简介 K近邻法(knn)是一种基本的分类与回归方法.k-means是一种简单而有效的聚类方法.虽然两者用途不同.解决的问题不同,但是在算法上有很多相似性,于是将二者放在一起,这样能够更好地对比二者的异 ...

  8. Full-Stack-Fundation-Udacity------Lesson 1 Working with CRUD

    因为手头在做一个项目,我负责后台,就顺带快进学习Udacity上一个水课(?):Full Stack Foundation.上课的好像是个印度小哥(?),按1.5倍速听讲话还是有点逗的.废话不多说,进 ...

  9. 第一章 创建WEB项目

    第一章   创建WEB项目 一.Eclipse创建WEB项目 方法/步骤1 首先,你要先打开Eclipse软件,打开后在工具栏依次点击[File]>>>[New]>>&g ...

  10. 创建帧动画1 - xml方式

    废话不多说,先看东西   创建帧动画1 - xml方式 帧动画的创建方式主要以下2种: * 用xml创建动画: * 用代码创建动画:   本文内容主要关注 xml文件 创建帧动画的方式   xml文件 ...