题意:

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

第一行, 两个整数 N, M, 分别表示最初的原子数目和事件总数。
第二行, N 个整数 E1, E2, …, EN, 由空格隔开。依次表示每个原子的能量。
接下来 M 行, 每行为一个字符串和两个整数, 描述一次事件,格式见题目描述。
N<=100,000,M<=100,0001 ≤ e, Ei ≤ 109。
设 N’ 为当前时刻原子数目。对于 merge 类事件, 1 ≤ x ≤ N’-1;
对于 insert 类事件, 1 ≤ x ≤ N’;
对于 max 和 min 类事件, 1 ≤ x < y ≤ N’。
任何时刻,保证 N’ ≥ 2。

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的更多相关文章

  1. 【BZOJ4864】神秘物质 [Splay]

    神秘物质 Time Limit: 10 Sec  Memory Limit: 256 MB Description Input Output Sample Input Sample Output 1 ...

  2. [BZOJ4864][BeiJing2017Wc]神秘物质(splay)

    首先merge就是先delete两次再insert,Max就是整个区间的最大值减最小值,Min就是区间中所有相邻两数差的最小值. Splay支持区间最大值,区间最小值,区间相邻差最小值即可. #inc ...

  3. BZOJ 4864 [BJWC2017]神秘物质 (splay)

    题目大意: 让你维护一个序列,支持: 1.合并两个相邻的数为一个新的数 2.在某个位置插入一个数 3.查询一个区间的任意子区间极差的最大值 4.查询一个区间的任意子区间极差的最小值 前两个操作可以用$ ...

  4. 【BZOJ4864】[BeiJing 2017 Wc]神秘物质 Splay

    [BZOJ4864][BeiJing 2017 Wc]神秘物质 Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微 ...

  5. [bzoj4864][BeiJing2017Wc]神秘物质_非旋转Treap

    神秘物质 bzoj-4864 BeiJing-2017-Wc 题目大意:给定一个长度为n的序列,支持插入,将相邻两个元素合并并在该位置生成一个指定权值的元素:查询:区间内的任意一段子区间的最大值减最小 ...

  6. BZOJ4864: [BeiJing 2017 Wc]神秘物质(Splay)

    Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微观粒子.这 一天, 小诚刚从研究所得到了一块奇异的陨石样本, 便 ...

  7. 【bzoj4864】神秘物质

    Description 给出一个长度为n的序列,第i个数为ai,进行以下四种操作: merge x e:将当前第x个数和第x+1个数合并,得到一个新的数e: insert x e:在当前第x个数和第x ...

  8. BZOJ_4864_[BeiJing 2017 Wc]神秘物质_Splay

    BZOJ4864_[BeiJing 2017 Wc]神秘物质_Splay Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天 ...

  9. BZOJ 4864: [BeiJing 2017 Wc]神秘物质 解题报告

    4864: [BeiJing 2017 Wc]神秘物质 Description 21ZZ 年,冬. 小诚退休以后, 不知为何重新燃起了对物理学的兴趣. 他从研究所借了些实验仪器,整天研究各种微观粒子. ...

随机推荐

  1. (13)处理静态资源(默认资源映射)【从零开始学Spring Boot】

    Spring Boot 默认为我们提供了静态资源处理,使用 WebMvcAutoConfiguration 中的配置各种属性. 建议大家使用Spring Boot的默认配置方式,如果需要特殊处理的再通 ...

  2. VMware 12安装CentOS 6.9时出现:The centos disc was not found in any of your drives.Please insert the centos disc and press OK to retry

    错误: The centos disc was not found in any of your drives.Please insert the centos disc and press OK t ...

  3. EL表达式无法被解析

    刚困死了,但是手上还在debug一个东西.然后就发现

  4. C语言学习笔记:15_c语言中的进制操作.c

    /* * 15_c语言中的进制操作.c * * Created on: 2015年7月5日 * Author: zhong */ #include <stdio.h> #include & ...

  5. js 判断 wifi and 流量

    var connection = navigator.connection || navigator.mozConnection || navigator.webkitConnection || { ...

  6. BNU 51638 Air Hockey 三分二分法

    Air Hockey   无聊的过河船同学和无聊的胀鱼同学非常喜欢打桌上冰球(其实只是喜欢听球碰撞时的声音).在无聊的一天,无聊的过河船同学想到了一个无聊的玩法:两人同时将两个球放桌面上,同时击出,然 ...

  7. iOS10 推送通知 UserNotifications

    简介 新框架 获取权限 获取用户设置 注册APNS,获取deviceToken 本地推送流程 远程推送流程 通知策略(Category+Action) 附件通知 代理回调 简介 iOS10新增了Use ...

  8. angular里使用vue/vue组件怎么在angular里用

    欢迎加入前端交流群交流知识&&获取视频资料:749539640 如何在angularjs(1)中使用vue参考: https://medium.com/@graphicbeacon/h ...

  9. Elasticsearch之cur查询索引

    前提, Elasticsearch之curl创建索引库 Elasticsearch之curl创建索引 Elasticsearch之curl创建索引库和索引时注意事项 Elasticsearch之cur ...

  10. css简单介绍

    css层叠样式表,主要作用就是解决内容与表现分离的问题.html标签有自己的意义当然也是有自己的默认样式的,但有时候我们想修改他的样式,这时候就需要了css. 例:给字体加上颜色,我们有如下几种方法: ...