【splay模板】
#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模板】的更多相关文章
- bzoj 1588 splay模板题
用晚自习学了一下splay模板,没想象中那么难,主要是左旋和右旋可以简化到一个函数里边,减少代码长度... #include<iostream> #include<cstdio> ...
- COJ 1002 WZJ的数据结构(二)(splay模板)
我的LCC,LCT,Splay格式终于统一起来了... 另外..这个形式的Splay是标准的Splay(怎么鉴别呢?看Splay函数是否只传了一个变量node就行),刘汝佳小白书的Splay写的真是不 ...
- Splay 模板
Splay 模板 struct SplayTree{ const static int maxn = 1e5 + 15; int ch[maxn][2] , key[maxn] , s[maxn] , ...
- [luogu3369/bzoj3224]普通平衡树(splay模板、平衡树初探)
解题关键:splay模板题整理. 如何不加入极大极小值?(待思考) #include<cstdio> #include<cstring> #include<algorit ...
- BZOJ1588 [HNOI2002]营业额统计 splay模板
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MB Submit: 16189 Solved: 6482 [Submit][S ...
- 文艺平衡树(splay模板)
题干:splay模板,要求维护区间反转. splay是一种码量小于treap,但支持排名,前驱后继等treap可求的东西,也支持区间反转的平衡树. 但是有两个坏处: 1.splay常数远远大于trea ...
- [洛谷P3391] 文艺平衡树 (Splay模板)
初识splay 学splay有一段时间了,一直没写...... 本题是splay模板题,维护一个1~n的序列,支持区间翻转(比如1 2 3 4 5 6变成1 2 3 6 5 4),最后输出结果序列. ...
- bzoj 1208 splay模板题2
自己yy了找前驱和后继,学了学怎么删除...(反正就是练模板) #include<iostream> #include<cstdio> #include<cstring& ...
- 【BZOJ 3196】二逼平衡树 线段树套splay 模板题
我写的是线段树套splay,网上很多人写的都是套treap,然而本蒟蒻并不会treap 奉上sth神犇的模板: //bzoj3196 二逼平衡树,支持修改某个点的值,查询区间第k小值,查询区间某个值排 ...
- 【BZOJ 3188】【Coci 2011】Upit Splay模板题
转啊转终于转出来了,然而我的模板跟陈竞潇学长的模板一模一样,还是太弱啊,第一次用指针. #include<cstdio> #include<cstring> #include& ...
随机推荐
- showModalDialog 的重要提示
模态对话框,没有opener,不能用window.opener.location.reload();或window.parent.location.reload();要通过返回值来判断关闭后刷新. f ...
- Python体验(10)-图形界面之计算器
import wx class Form(wx.Frame): def __init__( self, parent, id, title ): wx.Frame.__init__(self,pare ...
- leetcode-【中等题】5. Longest Palindromic Substring
题目 Given a string S, find the longest palindromic substring in S. You may assume that the maximum le ...
- 巧用freemarker
使用Freemarker宏进行可扩展式模块化编程 该文是转载而来,并非我本人所写,但是觉得真心不错,所以收藏一下 一.前言 今天的文章聊一下freemarker的一些特性:宏,我们将使用它写出一些模块 ...
- 用adox 取 access 自增列
百度很久 最后在 (.NET2.0下用ADOX动态创建ACCESS数据库(C#)) http://blog.csdn.net/black4371/article/details/4423739 找到了 ...
- java学习第18天(map集合)
Map集合是将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. 存储的是键值对形式的元素,键唯一,值可以重复,有点类似于数据库中的主键加数据.主要功能有: A:添加功能 put ...
- ASP.NET 常用状态(信息)保存方式
服务器端:Session(会话)/ Application/ Caching(缓存)/DataBase(数据库) Session: Session: 常用于保存登录用户ID.验证码 不同的浏览器不能共 ...
- Matlab melband的计算
%% mel bankmelnum = 24;low = 0;high = 0.5;melbank=melbankm(melnum,fftsize,Fs,low,high,'m');%归一化mel滤波 ...
- solrCloud+tomcat+zookeeper集群配置
solrcolud安装solrCloud+tomcat+zookeeper部署 转载请出自出处:http://eksliang.iteye.com/blog/2107002 http://eksli ...
- Perl爬取铁路违章旅客信息
#! /usr/bin/perl use strict; use Encode qw(encode decode); binmode(STDIN,":encoding(utf8)" ...