【BZOJ4864】[BeiJing 2017 Wc]神秘物质 Splay
【BZOJ4864】[BeiJing 2017 Wc]神秘物质
Description
Input
Output
Sample Input
5 8 10 2
max 1 3
min 1 3
max 2 4
Sample Output
题解:易知任意区间中的极差的最大值就是整个区间的极差,任意极差的最小值一定是相邻两数之差的最小值,我们可以用Splay来维护以下几个信息
1.区间最大值2.区间最小值3.区间相邻两数之差的最小值
因为在Splay旋转过程中,相邻两数之差是不会变的,所以将相邻两数之差统一由在左边的那个数保存,查询时右端点-1就行了
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
int tot,n,m,root;
struct node
{int fa,ch[2],siz,sw,w,sm,sn,v;
}s[200010];
int num[200010];
char str[20];
int rd()
{int ret=0; char gc=getchar();while(gc<'0'||gc>'9') gc=getchar();while(gc>='0'&&gc<='9') ret=ret*10+gc-'0',gc=getchar();return ret;
}
void pushup(int x)
{s[x].siz=s[s[x].ch[0]].siz+s[s[x].ch[1]].siz+1;s[x].sm=max(max(s[x].v,s[s[x].ch[0]].sm),s[s[x].ch[1]].sm);s[x].sn=min(min(s[x].v,s[s[x].ch[0]].sn),s[s[x].ch[1]].sn);s[x].sw=min(min(s[x].w,s[s[x].ch[0]].sw),s[s[x].ch[1]].sw);
}
void rotate(int x,int &k)
{int y=s[x].fa,z=s[y].fa,d=(x==s[y].ch[1]);if(y==k) k=x;else s[z].ch[y==s[z].ch[1]]=x;s[x].fa=z,s[y].fa=x,s[y].ch[d]=s[x].ch[d^1];if(s[x].ch[d^1]) s[s[x].ch[d^1]].fa=y;s[x].ch[d^1]=y;pushup(y),pushup(x);
}
void splay(int x,int &k)
{while(x!=k){int y=s[x].fa,z=s[y].fa;if(y!=k){if((x==s[y].ch[0])^(y==s[z].ch[0])) rotate(x,k);else rotate(y,k);}rotate(x,k);}
}
int find(int x,int y)
{if(!x) return 0;if(y<=s[s[x].ch[0]].siz) return find(s[x].ch[0],y);if(y==s[s[x].ch[0]].siz+1) return x;return find(s[x].ch[1],y-s[s[x].ch[0]].siz-1);
}
void build(int l,int r,int last)
{if(l>r) return ;int mid=l+r>>1;s[mid].fa=last,s[last].ch[mid>last]=mid;build(l,mid-1,mid),build(mid+1,r,mid);pushup(mid);
}
int main()
{n=rd(),m=rd();int i,a,b;s[0].sn=s[0].sw=1<<30;for(i=2;i<=n+1;i++) s[i].v=rd();for(i=2;i<=n+1;i++) s[i].w=abs(s[i].v-s[i+1].v);tot=n+2,root=tot+1>>1;build(1,root-1,root),build(root+1,tot,root);pushup(root);for(i=1;i<=m;i++){scanf("%s",str),a=rd(),b=rd();switch(str[1]){case 'e':splay(find(root,a+1),root),splay(find(root,a+3),s[root].ch[1]);s[s[root].ch[1]].ch[0]=0,pushup(s[root].ch[1]);s[root].v=b,s[root].w=abs(b-s[s[root].ch[1]].v);splay(find(root,a),s[root].ch[0]),s[s[root].ch[0]].w=abs(s[s[root].ch[0]].v-b);pushup(s[root].ch[0]),pushup(root); break;case 'n':splay(find(root,a+1),root),splay(find(root,a+2),s[root].ch[1]);s[s[root].ch[1]].ch[0]=++tot,s[tot].fa=s[root].ch[1],s[root].w=abs(s[root].v-b);s[tot].v=b,s[tot].w=abs(b-s[s[root].ch[1]].v),pushup(tot);pushup(s[root].ch[1]),pushup(root); break;case 'a':splay(find(root,a),root),splay(find(root,b+2),s[root].ch[1]);printf("%d\n",s[s[s[root].ch[1]].ch[0]].sm-s[s[s[root].ch[1]].ch[0]].sn); break;case 'i':splay(find(root,a),root),splay(find(root,b+1),s[root].ch[1]);printf("%d\n",s[s[s[root].ch[1]].ch[0]].sw); break;}}return 0;
}
转载于:https://www.cnblogs.com/CQzhangyu/p/6801523.html
【BZOJ4864】[BeiJing 2017 Wc]神秘物质 Splay相关推荐
- BZOJ4864: [BeiJing 2017 Wc]神秘物质(Splay)
Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微观粒子.这 一天, 小诚刚从研究所得到了一块奇异的陨石样本, 便 ...
- bzoj4864: [BeiJing 2017 Wc]神秘物质
4864: [BeiJing 2017 Wc]神秘物质 Time Limit: 20 Sec Memory Limit: 256 MB Submit: 99 Solved: 56 [Submit] ...
- 【bzoj4864】[BeiJing 2017 Wc]神秘物质 Splay
原文地址:http://www.cnblogs.com/GXZlegend/p/6801631.html 题目描述 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借 ...
- bzoj4864 [BeiJing 2017 Wc]神秘物质
(http://www.elijahqi.win/2018/01/26/bzoj4864-beijing-2017-wc%E7%A5%9E%E7%A7%98%E7%89%A9%E8%B4%A8/%20 ...
- bzoj 4864: [BeiJing 2017 Wc]神秘物质 splay
Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微观粒子.这 一天, 小诚刚从研究所得到了一块奇异的陨石样本, 便 ...
- BZOJ4864[BeiJing 2017 Wc]神秘物质——非旋转treap
题目描述 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微观粒子.这 一天, 小诚刚从研究所得到了一块奇异的陨石样本, 便迫不及待地开始 ...
- BZOJ_4864_[BeiJing 2017 Wc]神秘物质_Splay
BZOJ4864_[BeiJing 2017 Wc]神秘物质_Splay Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天 ...
- 4864: [BeiJing 2017 Wc]神秘物质
4864: [BeiJing 2017 Wc]神秘物质 Time Limit: 20 Sec Memory Limit: 256 MB Submit: 92 Solved: 50 [Submit][S ...
- [BZOJ]4864: [BeiJing 2017 Wc]神秘物质
题解: 操作1 分解为删除一个元素和修改一个元素的权值 操作2:插入一个元素 操作3:查询区间里面子区间的极差最大值 等价于直接求区间最大值减去区间最小值 操作4:查询区间子区间里面极差最小值 ...
最新文章
- 关于Vue中常用的工具函数封装
- mysql between and 包含边界吗_MySQL | SQL语法(一)
- css为什么要用浮动_css浮动的特性,与浮动带来的影响以及如何清除浮动
- HiveJDBC与其他JDBC一起使用时出现java.lang.IllegalArgumentException: Bad URL format
- Project Student:维护Webapp(只读)
- vmware中装的ubuntu上不了网
- 如何去除计算机的访问限制,访问限制达成,教你如何禁止别人访问你电脑的C盘...
- swift 自定义TabBarItem
- curviloft插件怎么用_Curviloft插件下载
- linux系统中rpm啥意思,Linux系统中的RPM简说
- Scarpy源码分析6
- javaScript特殊知识点归纳
- html页面banner空白,css banner不拉伸
- 嵌入式软件测试环境搭建,基于DOORS的嵌入式软件测试环境需求管理
- mysql neq什么意思_【知识科普】标准中的Eqv、Idt和Neq分别代表什么?
- 计算机教室怎么通电,多媒体电教室系统
- MogileFS部署流程
- Elasticsearch在docker下安装运行,ES查询、分词器
- 高斯噪声/白噪声/高斯白噪声的区别
- 七月算法机器学习笔记4 凸优化
热门文章
- Au入门系列之十:母带处理
- java计算机毕业设计-高中辅助教学系统-源程序+mysql+系统+lw文档+远程调试
- C语言求组合数C35,巧用组合数的性质求和
- python网络编程案例—五子棋游戏
- Hive性能优化(全面)解决数据倾斜等问题
- 计算机 无法 访问共享网络打印机,“无法连接到网络共享打印机”的常见原因和解决方法:...
- SAP QM初阶之事务代码QC51为采购订单创建Quality Certificate
- android图形动画
- 2022年驾驶员考试推土机司机多选题专项训练及答案
- 孙陶然:企业必须与社会分享