【BZOJ4864】【BJWC2017】神秘物质 - Splay
题意:
Description
21ZZ 年,冬。小诚退休以后, 不知为何重新燃起了对物理学的兴趣。 他从研究所借了些实验仪器,整天研究各种微观粒子。这一天, 小诚刚从研究所得到了一块奇异的陨石样本, 便迫不及待地开始观测。 在精密仪器的视野下,构成陨石的每个原子都无比清晰。 小诚发现, 这些原子排成若干列, 每一列的结构具有高度相似性。于是,他决定对单独一列原子进行测量和测试。被选中的这列共有 N 个顺序排列的原子。 最初, 第 i 个原子具有能量 Ei。 随着时间推移和人为测试, 这列原子在观测上会产生两种变化:
merge x e 当前第 x 个原子和第 x+1 个原子合并,得到能量为 e 的新原子;
insert x e 在当前第 x 个原子和第 x+1 个原子之间插入一个能量为 e 的新原子。
对于一列原子,小诚关心的是相邻一段中能量最大和能量最小的两个原子的能量差值,
称为区间极差。 因此, 除了观测变化外,小诚还要经常统计这列原子的两类数据:
max x y 当前第 x 到第 y 个原子之间的任意子区间中区间极差的最大值;
min x y 当前第 x 到第 y 个原子之间的任意子区间中区间极差的最小值。
其中, 子区间指的是长度至少是 2 的子区间。
小诚坚信这项研究可以获得诺贝尔物理学奖。为了让小诚早日了结心愿,你能否帮助他实现上述的观测和测量呢?
Input
Output
输出若干行, 按顺序依次表示每次 max 和 min 类事件的测量结果。
题解:
看到merge和insert操作肯定是splay维护啦……
考虑如何处理询问,极差最大值肯定是区间最大值减最小值,这个不用说;
极差最小值呢?
结论是极差最小值一定是两个相邻的数之差;
考虑三个数,肯定选中间的数和与其差较小的另一个数极差最小,三个数都选不会优于这个选择,类似归纳即可;
那么splay维护子树最大/最小值,前驱后继和子树内最小极差,pushup的时候搞搞即可。
代码:
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<queue>
#define inf 1000000007
#define eps 1e-9
using namespace std;
typedef long long ll;
typedef double db;
struct node{
int son[],fa,v,l,r,siz,mi,mx,mm;
}t[];
int n,m,x,y,rt,cnt,num[];
char op[];
bool Son(int u){
return t[t[u].fa].son[]==u;
}
void pushup(int u){
t[u].l=t[u].son[]?t[t[u].son[]].l:u;
t[u].r=t[u].son[]?t[t[u].son[]].r:u;
t[u].siz=t[t[u].son[]].siz+t[t[u].son[]].siz+;
t[u].mx=max(t[u].v,max(t[t[u].son[]].mx,t[t[u].son[]].mx));
t[u].mi=min(t[u].v,min(t[t[u].son[]].mi,t[t[u].son[]].mi));
t[u].mm=min(min(t[t[u].son[]].mm,t[t[u].son[]].mm),min(t[u].son[]?abs(t[u].v-t[t[t[u].son[]].r].v):inf,t[u].son[]?abs(t[u].v-t[t[t[u].son[]].l].v):inf));
}
int build(int l,int r,int ff){
int mid=(l+r)/;
t[mid].fa=ff;
if(l<mid)t[mid].son[]=build(l,mid-,mid);
if(mid<r)t[mid].son[]=build(mid+,r,mid);
pushup(mid);
return mid;
}
void rotate(int u){
int f=t[u].fa,ff=t[f].fa,ch=Son(u),cf=Son(f);
t[f].son[ch]=t[u].son[ch^];
t[t[f].son[ch]].fa=f;
t[ff].son[cf]=u;
t[u].son[ch^]=f;
t[u].fa=ff;
t[f].fa=u;
pushup(f);
pushup(u);
}
void splay(int u,int to){
for(;t[u].fa!=to;rotate(u)){
int f=t[u].fa;
if(t[f].fa!=to)rotate(Son(u)^Son(f)?u:f);
}
if(!to)rt=u;
}
int findx(int u,int k){
int nw=u;
for(;;){
if(t[t[nw].son[]].siz+==k)return nw;
if(k<=t[t[nw].son[]].siz){
nw=t[nw].son[];
}else{
k-=t[t[nw].son[]].siz+;
nw=t[nw].son[];
}
}
}
int split(int x,int y){
int l=findx(rt,x-),r=findx(rt,y+);
//printf("%d %d\n",l,r);
splay(l,);
splay(r,rt);
return t[t[rt].son[]].son[];
}
void merge(int x,int y){
int u=split(x+,x+);
t[u].v=y;
t[u].son[]=t[u].son[]=;
pushup(u);
pushup(t[rt].son[]);
pushup(rt);
}
void ins(int x,int y){
int u=split(x+,x+);
t[t[rt].son[]].son[]=++cnt;
t[cnt].fa=t[rt].son[];
t[cnt].v=y;
pushup(cnt);
pushup(t[rt].son[]);
pushup(rt);
}
int getmx(int x,int y){
int u=split(x+,y+);
return t[u].mx-t[u].mi;
}
int getmi(int x,int y){
int u=split(x+,y+);
return t[u].mm;
}
int main(){
scanf("%d%d",&n,&m);
cnt=n+;
for(int i=;i<=n;i++){
scanf("%d",&t[i+].v);
}
t[].mx=;
t[].mi=t[].mm=inf;
cnt=n+;
rt=build(,n+,);
for(int i=;i<=m;i++){
scanf("%s%d%d",op,&x,&y);
if(op[]=='e'){
merge(x,y);
}else if(op[]=='n'){
ins(x,y);
}else if(op[]=='a'){
printf("%d\n",getmx(x,y));
}else{
printf("%d\n",getmi(x,y));
}
}
return ;
}
【BZOJ4864】【BJWC2017】神秘物质 - Splay的更多相关文章
- 【BZOJ4864】神秘物质 [Splay]
神秘物质 Time Limit: 10 Sec Memory Limit: 256 MB Description Input Output Sample Input Sample Output 1 ...
- [BZOJ4864][BeiJing2017Wc]神秘物质(splay)
首先merge就是先delete两次再insert,Max就是整个区间的最大值减最小值,Min就是区间中所有相邻两数差的最小值. Splay支持区间最大值,区间最小值,区间相邻差最小值即可. #inc ...
- BZOJ 4864 [BJWC2017]神秘物质 (splay)
题目大意: 让你维护一个序列,支持: 1.合并两个相邻的数为一个新的数 2.在某个位置插入一个数 3.查询一个区间的任意子区间极差的最大值 4.查询一个区间的任意子区间极差的最小值 前两个操作可以用$ ...
- 【BZOJ4864】[BeiJing 2017 Wc]神秘物质 Splay
[BZOJ4864][BeiJing 2017 Wc]神秘物质 Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微 ...
- [bzoj4864][BeiJing2017Wc]神秘物质_非旋转Treap
神秘物质 bzoj-4864 BeiJing-2017-Wc 题目大意:给定一个长度为n的序列,支持插入,将相邻两个元素合并并在该位置生成一个指定权值的元素:查询:区间内的任意一段子区间的最大值减最小 ...
- BZOJ4864: [BeiJing 2017 Wc]神秘物质(Splay)
Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微观粒子.这 一天, 小诚刚从研究所得到了一块奇异的陨石样本, 便 ...
- 【bzoj4864】神秘物质
Description 给出一个长度为n的序列,第i个数为ai,进行以下四种操作: merge x e:将当前第x个数和第x+1个数合并,得到一个新的数e: insert x e:在当前第x个数和第x ...
- BZOJ_4864_[BeiJing 2017 Wc]神秘物质_Splay
BZOJ4864_[BeiJing 2017 Wc]神秘物质_Splay Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天 ...
- BZOJ 4864: [BeiJing 2017 Wc]神秘物质 解题报告
4864: [BeiJing 2017 Wc]神秘物质 Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微观粒子. ...
随机推荐
- dubbo-dubboAdmin安装(一)
简介 Dubbo是什么? dubbo是阿里开源的分布式服务治理框架,对服务的负载均衡,权重,监控,路由规则,禁用启用的管理,以及服务的自动注册和发现 分布式架构下面临问题 在分布式架构下,我们会将一个 ...
- navicat 为表添加索引
navicat 为表添加索引 分析常用的查询场景,为字段添加索引,增加查询速度. 可以添加单列索引,可以添加联合索引. 右键,设计表中可以查看和添加修改索引! 索引一定要根据常用的查询场景进行添加! ...
- 0728MySQL数据库InnoDB存储引擎重做日志漫游REDOLOG,UNDOLOG
转自http://www.mysqlops.com/2012/04/06/innodb-log1.html 00 – Undo LogUndo Log 是为了实现事务的原子性,在MySQL数据库Inn ...
- 用JAVA的抽象类实现编码组合进度的灵活性
都是实际开发逼出来的吧. 人类真灵活~~~~:) 就是将整个功能的实现在编程时,打散到一个一个文件中,提前写好核心算法, 在TEAM的实现方案确定下来之后,再进行组装. GuessGame.java ...
- [bzoj2131]免费的馅饼_树状数组
免费的馅饼 bzoj-2131 题目大意: 注释:$1\le n \le 10^5$,$1\le w \le 10^8$. 想法:首先,想到dp 状态:dp[i][j]表示i分钟在位置j的最大收益 优 ...
- GNUPlot绘制曲线
发现gnuplot在mac上编译安装相当方便,在线下为了測试java老堆和lucene索引大小,须要绘制两条线,可是直接点连的线很难看,所以后面使用贝塞尔曲线. 脚本例如以下: #! /usr/loc ...
- 并查集图冲突hdu1272
还是属于并查集的变形 两个点仅仅有一条路径连通 给出的两个点事先都是属于两个集合的 须要给出的着条边构成一个集合 算法复杂度还是挺高的 每一个我都循环了100000次 set2数组没清空 wrong了 ...
- java 源代码的魅力
学习一种语言: 最快的方法.就是研究其源码. 从源码中可以体会到各种经典的思想! 赞赏一下: 比如: 我们在写一些 冒泡和选择排序的时候用的 交换: /** * Swaps x[a] ...
- JPA相关注解
JPA注解 一.基本注解 1.表相关 @Entity 仅仅要加了这个注解就具备了表和实体的映射关系,表名就是实体名 @Table(name="表名") 一般和实体 ...
- nexus启动报错----->错误 1067: 进程意外终止。
1.今天启动nexus报错: 2.错误信息 错误 1067: 进程意外终止. 3.检查发现我之前把jdk升级了.然而nexus之前指定的jdk将不再生效. 4.解决办法 找到nexus安装目录 修改b ...