https://www.lydsy.com/JudgeOnline/problem.php?id=1500

https://www.luogu.org/problemnew/show/P2042#sub

请写一个程序,要求维护一个数列,支持以下 6 种操作:
请注意,格式栏 中的下划线‘ _ ’表示实际输入文件中的空格

太神啦太神啦,我也不会做,我也是copycat的啊。

https://www.luogu.org/blog/IAmHellWord/solution-p2042

直接看上面这位神犇的题解吧。

#include<cstdio>
#include<queue>
#include<cctype>
#include<cstring>
#include<cmath>
#include<vector>
#include<algorithm>
using namespace std;
const int N=1e6+;
const int INF=1e9;
inline int read(){
int X=,w=;char ch=;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch))X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
char s[];
int fa[N],tr[N][],key[N],size[N],mx[N];
int root,sz,a[N],id[N],sum[N],lx[N],rx[N];
bool rev[N],tag[N];
queue<int>q;
inline void pushup(int x){
int l=tr[x][],r=tr[x][];
sum[x]=sum[l]+sum[r]+key[x];
size[x]=size[l]+size[r]+;
mx[x]=max(mx[l],max(mx[r],rx[l]+key[x]+lx[r]));
lx[x]=max(lx[l],sum[l]+key[x]+lx[r]);
rx[x]=max(rx[r],sum[r]+key[x]+rx[l]);
}
inline void pushdown(int x){
int l=tr[x][],r=tr[x][];
if(tag[x]){
rev[x]=tag[x]=;
if(l)tag[l]=,key[l]=key[x],sum[l]=key[x]*size[l];
if(r)tag[r]=,key[r]=key[x],sum[r]=key[x]*size[r];
if(key[x]>=){
if(l)lx[l]=rx[l]=mx[l]=sum[l];
if(r)lx[r]=rx[r]=mx[r]=sum[r];
}else{
if(l)lx[l]=rx[l]=,mx[l]=key[x];
if(r)lx[r]=rx[r]=,mx[r]=key[x];
}
}
if(rev[x]){
rev[x]=;rev[l]^=;rev[r]^=;
swap(lx[l],rx[l]);swap(lx[r],rx[r]);
swap(tr[l][],tr[l][]);swap(tr[r][],tr[r][]);
}
}
inline bool get(int x){
return tr[fa[x]][]==x;
}
inline void rotate(int x){
int y=fa[x],z=fa[y],which=get(x);
tr[y][which]=tr[x][which^];fa[tr[y][which]]=y;
fa[y]=x;tr[x][which^]=y;fa[x]=z;
if(z)tr[z][tr[z][]==y]=x;
pushup(y);pushup(x);
return;
}
inline void splay(int x,int y){
int f=fa[x];
while(f!=y){
if(fa[f]!=y)rotate(get(x)==get(f)?f:x);
rotate(x);f=fa[x];
}
if(!y)root=x;
return;
}
inline int findx(int x){//找到排名为x的点
int now=root;
while(){
pushdown(now);
if(tr[now][]&&x<=size[tr[now][]])now=tr[now][];
else{
int temp=(tr[now][]?size[tr[now][]]:)+;
if(x==temp)return now;
x-=temp;now=tr[now][];
}
}
}
inline int split(int k,int tot){
int x=findx(k),y=findx(k+tot+);
splay(x,);splay(y,x);
return tr[y][];
}
inline void query(int k,int tot){
int x=split(k,tot);
printf("%d\n",sum[x]);
}
inline void modify(int k,int tot,int v){
int x=split(k,tot),y=fa[x];
key[x]=v;tag[x]=;sum[x]=size[x]*v;
if(v>=)lx[x]=rx[x]=mx[x]=sum[x];
else lx[x]=rx[x]=,mx[x]=v;
pushup(y);pushup(fa[y]);
}
inline void turn(int k,int tot){
int x=split(k,tot),y=fa[x];
if(!tag[x]){
rev[x]^=;
swap(tr[x][],tr[x][]);
swap(lx[x],rx[x]);
pushup(y);pushup(fa[y]);
}
return;
}
inline void recycle(int x){
int &l=tr[x][],&r=tr[x][];
if(l)recycle(l);
if(r)recycle(r);
q.push(x);
fa[x]=l=r=tag[x]=rev[x]=;
}
inline void build(int l,int r,int f){
int mid=(l+r)>>,now=id[mid],pre=id[f];
if(l==r){
mx[now]=sum[now]=a[l];
tag[now]=rev[now]=;
lx[now]=rx[now]=max(a[l],);
size[now]=;
}
if(l<mid)build(l,mid-,mid);
if(mid<r)build(mid+,r,mid);
key[now]=a[mid],fa[now]=pre;
pushup(now);
tr[pre][mid>=f]=now;
}
inline void insert(int k,int tot){
for(int i=;i<=tot;i++)a[i]=read();
for(int i=;i<=tot;i++){
if(!q.empty())id[i]=q.front(),q.pop();
else id[i]=++sz;
}
build(,tot,);
int z=id[(+tot)>>];
int x=findx(k+),y=findx(k+);
splay(x,);splay(y,x);
fa[z]=y;tr[y][]=z;
pushup(y);pushup(x);
return;
}
inline void del(int k,int tot){
int x=split(k,tot),y=fa[x];
recycle(x);tr[y][]=;
pushup(y);pushup(fa[y]);
return;
}
int main(){
int n=read(),m=read();
mx[]=a[]=a[n+]=-INF;
for(int i=;i<=n+;i++)a[i]=read();
for(int i=;i<=n+;i++)id[i]=i;
build(,n+,);
root=(n+)>>;sz=n+;
for(int i=;i<=m;i++){
scanf("%s",s);
if(s[]=='I'){
int k=read(),tot=read();
insert(k,tot);
}
if(s[]=='D'){
int k=read(),tot=read();
del(k,tot);
}
if(s[]=='M'){
if(s[]=='X')printf("%d\n",mx[root]);
else{
int k=read(),tot=read(),c=read();
modify(k,tot,c);
}
}
if(s[]=='R'){
int k=read(),tot=read();
turn(k,tot);
}
if(s[]=='G'){
int k=read(),tot=read();
query(k,tot);
}
}
return ;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

BZOJ1500:[NOI2005]维修数列——题解的更多相关文章

  1. [BZOJ1500][NOI2005]维修数列---解题报告

    Portal Gun:[BZOJ1500][NOI2005]维修数列 有一段时间没写博客了,最近在刚数据结构......各种板子背得简直要起飞,题目也是一大堆做不完,这里就挑一道平衡树的题来写写好了 ...

  2. [BZOJ1500][NOI2005]维修数列 解题报告 Splay

    Portal Gun:[BZOJ1500][NOI2005]维修数列 有一段时间没写博客了,最近在刚数据结构......各种板子背得简直要起飞,题目也是一大堆做不完,这里就挑一道平衡树的题来写写好了 ...

  3. bzoj千题计划221:bzoj1500: [NOI2005]维修数列(fhq treap)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1500 1.覆盖标记用INF表示无覆盖标记,要求可能用0覆盖 2.代表空节点的0号节点和首尾的两个虚拟 ...

  4. splay模板三合一 luogu2042 [NOI2005]维护数列/bzoj1500 [NOI2005]维修数列 | poj3580 SuperMemo | luogu3391 【模板】文艺平衡树(Splay)

    先是维修数列 题解看这里,但是我写的跑得很慢 #include <iostream> #include <cstdio> using namespace std; int n, ...

  5. [bzoj1500][NOI2005]维修数列_非旋转Treap

    维修数列 bzoj-1500 NOI-2005 题目大意:给定n个数,m个操作,支持:在指定位置插入一段数:删除一个数:区间修改:区间翻转.查询:区间和:全局最大子序列. 注释:$1\le n_{ma ...

  6. BZOJ1500[NOI2005]维修数列

    Description Input 输入的第1 行包含两个数N 和M(M ≤20 000),N 表示初始时数列中数的个数,M表示要进行的操作数目.第2行包含N个数字,描述初始时的数列.以下M行,每行一 ...

  7. [bzoj1500][NOI2005]维修数列——splay

    题目 题解 这道题可以说是数列问题的大BOSS,也算是这一周来学习splay等数据结构的一个总结. 我们一个一个地看这些操作. 对于操作1,我们首先建一棵子树,直接接上原树即可. 对于操作2,我们找到 ...

  8. BZOJ1500 [NOI2005]维修数列(Splay tree)

    [Submit][Status][Discuss] Description 请写一个程序,要求维护一个数列,支持以下 6 种操作: 请注意,格式栏 中的下划线‘ _ ’表示实际输入文件中的空格 Inp ...

  9. BZOJ1500: [NOI2005]维修数列[splay ***]

    1500: [NOI2005]维修数列 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 12278  Solved: 3880[Submit][Statu ...

随机推荐

  1. svn 撤销 已提交的修改

    1.保证我们拿到的是最新代码:  svn update  假设最新版本号是28.  2.然后找出要回滚的确切版本号:  svn log [something]  假设根据svn log日志查出要回滚的 ...

  2. 【JUC源码解析】Exchanger

    简介 Exchanger,并发工具类,用于线程间的数据交换. 使用 两个线程,两个缓冲区,一个线程往一个缓冲区里面填数据,另一个线程从另一个缓冲区里面取数据.当填数据的线程将缓冲区填满时,或者取数据的 ...

  3. 说说NSCache优于NSDictionary的几点

    1.NSCache可以提供自动删减缓存功能,而且保证线程安全,与字典不同,不会拷贝键.2.NSCache可以设置缓存上限,限制对象个数和总缓存开销.定义了删除缓存对象的时机.这个机制只对NSCache ...

  4. RAP2环境搭建整理(超详细)

    RAP2是阿里开源的接口管理平台,最近搭建了一下,将部署文档整理如下: 如果途中遇坑会在文章末尾记录下来嘻嘻 首先,确定环境是否部署好. RAP2所需的环境为: node.js 8.9.4+ mysq ...

  5. Selenium自动化测试基础

    如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...

  6. 第六模块:WEB框架开发 第1章·Django框架开发50~87

    51-表关系之一对多 52-表关系之多对多 53-表关系之一对一 54-数据库表关系之关联字段与外键约束 55-数据库表关系之sql创建关联表 56-ORM生成关联表模型 57-多表操作之一对多添加记 ...

  7. FU-A方式分包

    当 NALU 的长度超过 MTU 时, 就必须对 NALU 单元进行分片封包. 也称为 Fragmentation Units (FUs).  0 1  2 3 0 1 2 3 4 5 6 7 8 9 ...

  8. Java并发基础--volatile关键字

    一.java内存模型 1.java内存模型 程序运行过程中的临时数据是存放在主存(物理内存)中,但是现代计算机CPU的运算能力和速度非常的高效,从内存中读取和写入数据的速度跟不上CPU的处理速度,在这 ...

  9. ionic ios样式偏移解决方案。

    在css属性内增加: .item-ios [item-end] { //解决ios系统上尾部图标出现重影而增加的格式. margin: 0px -15.3px 0px 0px; margin-bott ...

  10. Python3 Tkinter-Frame

    1.创建 from tkinter import * root=Tk() for fm in ['red','blue','yellow','green','white','black']: Fram ...