#include <iostream>
 #include <cstring>
 #include <algorithm>
 #include <cstdio>
 #include <queue>
 #define oo 1000000000
 #define lc(x) son[x][0]
 #define rc(x) son[x][1]
 using namespace std;
 int i,j,k,n,m,s,t,ans;
 ];
 struct node
 {
     int set,rever;
 } tag[];
 ][];
 ];
 ];
 ];
 ];
 ];
 ];
 ];
 ];
 queue <int> q;
 int root,cnt,pos;
 void update(int x)
 {
     size[x] = size[lc(x)]+size[rc(x)]+;
     tsum[x] = tsum[lc(x)]+tsum[rc(x)]+key[x];
     lmax[x] = max(lmax[lc(x)],tsum[lc(x)]+key[x]+lmax[rc(x)]);
     rmax[x] = max(rmax[rc(x)],tsum[rc(x)]+key[x]+rmax[lc(x)]);
     tmax[x] = max(max(tmax[lc(x)],tmax[rc(x)]),lmax[rc(x)]+key[x]+rmax[lc(x)]);
 }
 void Round(int x)
 {
     swap(lc(x),rc(x));
     swap(lmax[x],rmax[x]);
 }
 void build(int l,int r,int &x)
 {
     if (l>r)
     {
         x = ;
         return;
     }
     if (l==r)
     {
         if (!q.empty())
         {
             x = q.front();
             q.pop();
         } else x = ++cnt;
         tag[x].rever = ;
         tag[x].;
         key[x] = tsum[x] = tmax[x] = a[l];
         lmax[x] = rmax[x] = max(,a[l]);
         size[x] = ;
         lc(x) = rc(x) = ;
         return;
     }
     ;
     if (!q.empty())
     {
         x = q.front();
         q.pop();
     } else x = ++cnt;
     key[x] = a[mid];
     tag[x].rever = ;
     tag[x].;
     lc(x) = rc(x) = ;
     build(l,mid-,lc(x));
     build(mid+,r,rc(x));
     ) fa[lc(x)] = x;
     ) fa[rc(x)] = x;
     update(x);
 }
 void pushdown(int x)
 {
     )
     {
         tag[x].rever = ;
         tag[lc(x)].rever ^= ;
         tag[rc(x)].rever ^= ;
         Round(lc(x));
         Round(rc(x));
     }
     )
     {
         )
         {
             tag[lc(x)].set = tag[x].set;
             key[lc(x)] = tag[x].set;
             tsum[lc(x)] = tag[x].set*size[lc(x)];
             ) tmax[lc(x)] = lmax[lc(x)] = rmax[lc(x)] = tsum[lc(x)];
             else
             {
                 tmax[lc(x)] = tag[x].set;
                 lmax[lc(x)] = rmax[lc(x)] = ;
             }
         }
         )
         {
             tag[rc(x)].set = tag[x].set;
             key[rc(x)] = tag[x].set;
             tsum[rc(x)] = tag[x].set*size[rc(x)];
             ) tmax[rc(x)] = lmax[rc(x)] = rmax[rc(x)] = tsum[rc(x)];
             else
             {
                 tmax[rc(x)] = tag[x].set;
                 lmax[rc(x)] = rmax[rc(x)] = ;
             }
         }
         tag[x].;
     }
 }
 int find(int x,int k)
 {
     pushdown(x);
     ==k) return x;
     else if (size[lc(x)]>=k) return find(lc(x),k);
     );
 }
 void rotate(int x)
 {
     int y = fa[x],z = fa[y],w = lc(y)==x;
     pushdown(y);
     pushdown(x);
     fa[son[x][w]] = y;son[y][w^] = son[x][w];
     fa[x] = z;) son[z][rc(z)==y] = x;
     son[x][w] = y;fa[y] = x;
     update(y);
     update(x);
 }
 void splay(int x,int s)
 {
     pushdown(x);
     while (fa[x]!=s)
     {
         int y = fa[x],z = fa[y];
         if (z!=s) rotate(lc(z)==y^lc(y)==x?x:y);
         rotate(x);
     }
     update(x);
     ) root = x;
 }
 void insert(int pos)
 {
     int z;
     build(,n,z);
     int x = find(root,pos);
     );
     splay(x,);
     splay(y,root);
     lc(y) = z;
     fa[z] = y;
     update(y);
     update(x);
 }
 void del(int x)
 {
     ) return;
     del(lc(x));
     q.push(x);
     del(rc(x));
 }
 void erase(int pos,int n)
 {
     );
     int y = find(root,pos+n);
     splay(x,);
     splay(y,root);
     del(lc(y));
     lc(y) = ;
     update(y);
     update(x);
 }
 int main()
 {
     scanf("%d%d",&n,&m);
     a[] = a[n+] = -oo;
     tmax[] = -oo;
     ;i<=n+;i++) scanf("%d",&a[i]);
     build(,n+,root);
     while (m--)
     {
         ];
         scanf();
         ]=='I')
         {
             scanf("%d%d",&pos,&n);
             ;i<=n;i++)
             scanf("%d",&a[i]);
             insert(pos+);
         } ]=='D')
         {
             scanf("%d%d",&pos,&n);
             erase(pos+,n);
         } ]==]=='K')
         {
             int c;
             scanf("%d%d%d",&pos,&n,&c);
             int x = find(root,pos);
             );
             splay(x,);
             splay(y,root);
             tag[lc(y)].set = c;
             key[lc(y)] = c;
             tsum[lc(y)] = c*size[lc(y)];
             ) tmax[lc(y)] = lmax[lc(y)] = rmax[lc(y)] = tsum[lc(y)];
             else
             {
                 tmax[lc(y)] = c;
                 lmax[lc(y)] = rmax[lc(y)] = ;
             }
             update(y);
             update(x);
         } ]=='R')
         {
             scanf("%d%d",&pos,&n);
             int x = find(root,pos);
             );
             splay(x,);
             splay(y,root);
             tag[lc(y)].rever ^= ;
             Round(lc(y));
             update(y);
             update(x);
         } ]=='G')
         {
             scanf("%d%d",&pos,&n);
             int x = find(root,pos);
             );
             splay(x,);
             splay(y,root);
             printf("%d\n",tsum[lc(y)]);
         } else printf("%d\n",tmax[root]);
     }
     ;
 }

BZOJ1500 维修数列

【splay模板】的更多相关文章

  1. bzoj 1588 splay模板题

    用晚自习学了一下splay模板,没想象中那么难,主要是左旋和右旋可以简化到一个函数里边,减少代码长度... #include<iostream> #include<cstdio> ...

  2. COJ 1002 WZJ的数据结构(二)(splay模板)

    我的LCC,LCT,Splay格式终于统一起来了... 另外..这个形式的Splay是标准的Splay(怎么鉴别呢?看Splay函数是否只传了一个变量node就行),刘汝佳小白书的Splay写的真是不 ...

  3. Splay 模板

    Splay 模板 struct SplayTree{ const static int maxn = 1e5 + 15; int ch[maxn][2] , key[maxn] , s[maxn] , ...

  4. [luogu3369/bzoj3224]普通平衡树(splay模板、平衡树初探)

    解题关键:splay模板题整理. 如何不加入极大极小值?(待思考) #include<cstdio> #include<cstring> #include<algorit ...

  5. BZOJ1588 [HNOI2002]营业额统计 splay模板

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MB Submit: 16189  Solved: 6482 [Submit][S ...

  6. 文艺平衡树(splay模板)

    题干:splay模板,要求维护区间反转. splay是一种码量小于treap,但支持排名,前驱后继等treap可求的东西,也支持区间反转的平衡树. 但是有两个坏处: 1.splay常数远远大于trea ...

  7. [洛谷P3391] 文艺平衡树 (Splay模板)

    初识splay 学splay有一段时间了,一直没写...... 本题是splay模板题,维护一个1~n的序列,支持区间翻转(比如1 2 3 4 5 6变成1 2 3 6 5 4),最后输出结果序列. ...

  8. bzoj 1208 splay模板题2

    自己yy了找前驱和后继,学了学怎么删除...(反正就是练模板) #include<iostream> #include<cstdio> #include<cstring& ...

  9. 【BZOJ 3196】二逼平衡树 线段树套splay 模板题

    我写的是线段树套splay,网上很多人写的都是套treap,然而本蒟蒻并不会treap 奉上sth神犇的模板: //bzoj3196 二逼平衡树,支持修改某个点的值,查询区间第k小值,查询区间某个值排 ...

  10. 【BZOJ 3188】【Coci 2011】Upit Splay模板题

    转啊转终于转出来了,然而我的模板跟陈竞潇学长的模板一模一样,还是太弱啊,第一次用指针. #include<cstdio> #include<cstring> #include& ...

随机推荐

  1. List subList(startIndex, endIndex);

    1. subList(startIndex, endIndex);//startIndex开始,到endIndex结束,不包含endIndex! 2. 集合排序可以实现 java.util.Compa ...

  2. 在Linux上编写C#程序

    自从C#开源之后,在Linux编写C#程序就成了可能.Mono-project就是开源版本的C#维护项目.在Linux平台上使用的C#开发工具为monodevelop.安装方式如下: 首先需要安装一些 ...

  3. mvc action controller area

    获取控制器名称: ViewContext.RouteData.Values["controller"].ToString(); 获取Action名称: ViewContext.Ro ...

  4. xcode 插件地址

    http://finalshares.com/read-1104 curl -fsSL https://raw.githubusercontent.com/supermarin/Alcatraz/de ...

  5. openscales实现漂亮的冒泡效果

    使用的时候openscales 默认的冒泡效果确实有点简陋,想实现那种看着比较舒服的效果,只能自己定义了.参考现有的openscales实现的方式,它是通过控件的状态实现的,每个状态中使用Path绘制 ...

  6. Struts2:效验器——声明式

    就是用xml配置的方式,而不是Java代码的形式,那个是“编程式” Action: package org.ah.s2; import com.opensymphony.xwork2.ActionSu ...

  7. Bootstrap框架(基础篇)之按钮,网格,导航栏,下拉菜单

    一,按钮 注意:虽然在Bootstrap框架中使用任何标签元素都可以实现按钮风格,但个人并不建议这样使用,为了避免浏览器兼容性问题,个人强烈建议使用button或a标签来制作按钮. 框架中提供了基础按 ...

  8. js的事件的绑定

    js的绑定事件 绑定事件有什么用,当你一个按钮点击时需要执行2个函数,就可以用绑定事件,一般只有没绑定事件增加两个onclick函数,第二会覆盖第一个函数的. <!DOCTYPE html> ...

  9. zend studio中ctrl+鼠标左键无法转到类或函数定义文件的解决方法

    转载自:http://blog.csdn.net/wide288/article/details/21622183 zend studio中ctrl+鼠标左键无法转到类或函数定义文件的解决方法: ze ...

  10. Sublime Text 全程指引

    Sublime Text 全程指引 by Lucida 包含sublime 的常用快捷操作