#平衡树#洛谷 1110 [ZJOI2007]报表统计
分析
最小值只需要开两棵平衡树,一棵维护所有元素,一棵维护相邻最小值,
对于全局最小值,对于每次插入查找前驱后继更新最小值即可,
相邻最小值,对于每个原数列的数维护它的开头和结尾是什么数,
然后在往后插入一个数时直接先把原来的相邻删除再加进去,
求平衡树的最小值即可
代码
#include <cstdio>
#include <cctype>
#include <cstring>
#include <algorithm>
#define rr register
using namespace std;
const int N=500011,inf=1e9; char str[21];
const double alp=0.75; int ans,n,m,len,St[N],Ed[N],a[N];
inline signed iut(){
rr int ans=0,f=1; rr char c=getchar();
while (!isdigit(c)) f=(c=='-')?-f:f,c=getchar();
while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
return ans*f;
}
inline void print(int ans){
if (ans<0) putchar('-'),ans=-ans;
if (ans>9) print(ans/10);
putchar(ans%10+48);
}
inline signed min(int a,int b){return a<b?a:b;}
inline signed max(int a,int b){return a>b?a:b;}
struct ScapeGoat_Tree{
int siz[N<<1],son[N<<1][2],root,tot=0,fat[N<<1],w[N<<1],stac[N<<1],TOP;
inline void BUILD(){
tot=2,root=1;
w[1]=-inf,siz[1]=2,son[1][1]=2,
w[2]=inf,siz[2]=1,fat[2]=1;
}
inline bool balance(int x){return alp*siz[x]>=(max(siz[son[x][0]],siz[son[x][1]]));}
inline void recycle(int x){
if (son[x][0]) recycle(son[x][0]);
stac[++TOP]=x;
if (son[x][1]) recycle(son[x][1]);
}
inline signed build(int l,int r){
if (l>r) return 0;
rr int mid=(l+r)>>1,x=stac[mid];
fat[son[x][0]=build(l,mid-1)]=x;
fat[son[x][1]=build(mid+1,r)]=x;
siz[x]=siz[son[x][0]]+siz[son[x][1]]+1;
return x;
}
inline void rebuild(int x){
TOP=0; recycle(x);
rr int fa=fat[x],wh=son[fat[x]][1]==x;
rr int now=build(1,TOP);
fat[son[fa][wh]=now]=fa;
if (root==x) root=now;
}
inline void Insert(int x){
rr int now=root,renew=++tot;
siz[renew]=1,w[renew]=x;
while (1){
++siz[now];
rr bool wh=x>=w[now];
if (son[now][wh]) now=son[now][wh];
else {fat[son[now][wh]=renew]=now; break;}
}
rr int UP=0;
for (rr int i=renew;i;i=fat[i]) if (!balance(i)) UP=i;
if (UP) rebuild(UP);
}
inline void Delete(int x){
if (son[x][0]&&son[x][1]){
rr int now=son[x][0];
while (son[now][1]) now=son[now][1];
w[x]=w[now],x=now;
}
rr int cho=son[x][0]?son[x][0]:son[x][1],wh=son[fat[x]][1]==x;
fat[son[fat[x]][wh]=cho]=fat[x];
for (rr int i=fat[x];i;i=fat[i]) --siz[i];
if (x==root) root=cho;
}
inline signed arr(int x){
rr int now=root;
while (1){
if (w[now]==x) return now;
else now=son[now][w[now]<x];
}
}
inline signed rank(int x){
rr int now=root,ans=0;
while (now){
if (x>w[now]) ans+=siz[son[now][0]]+1,now=son[now][1];
else now=son[now][0];
}
return ans;
}
inline signed kth(int x){
rr int now=root;
while (1){
if (siz[son[now][0]]==x-1) return now;
else if (siz[son[now][0]]>=x) now=son[now][0];
else x-=siz[son[now][0]]+1,now=son[now][1];
}
}
inline signed pre(int x){
rr int now=root,ans=-inf;
while (now){
if (x>w[now]) ans=max(ans,w[now]),now=son[now][1];
else now=son[now][0];
}
return ans;
}
inline signed suf(int x){
rr int now=root,ans=inf;
while (now){
if (x<w[now]) ans=min(ans,w[now]),now=son[now][0];
else now=son[now][1];
}
return ans;
}
}Tre[2];
inline signed Abs(int x){return x<0?-x:x;}
signed main(){
n=iut(),m=iut(),Tre[0].BUILD(),Tre[1].BUILD();
for (rr int i=1;i<=n;++i) St[i]=Ed[i]=a[i]=iut();
for (rr int i=1;i<n;++i) Tre[0].Insert(Abs(St[i+1]-St[i]));
for (rr int i=1;i<=n;++i) Tre[1].Insert(St[i]);
sort(a+1,a+1+n),ans=Abs(a[2]-a[1]);
for (rr int i=3;i<=n;++i) ans=min(ans,Abs(a[i]-a[i-1]));
for (rr int i=1;i<=m;++i){
scanf("%s",str+1),len=strlen(str+1);
if (len==6){
rr int x=iut(),w=iut();
if (x<n) Tre[0].Delete(Tre[0].arr(Abs(St[x+1]-Ed[x])));
if (x<n) Tre[0].Insert(Abs(St[x+1]-w));
Tre[0].Insert(Abs(w-Ed[x])),Ed[x]=w;
rr int t1=Tre[1].suf(-inf),t2=Tre[1].pre(inf);
if (w<t1) ans=min(ans,t1-w);
else if (t2<w) ans=min(ans,w-t2);
else {
if (Tre[1].suf(w-1)==w) {ans=0; continue;}
ans=min(ans,min(w-Tre[1].pre(w),Tre[1].suf(w)-w));
}
Tre[1].Insert(w);
}else if (len==7) print(Tre[0].suf(-inf)),putchar(10);
else print(ans),putchar(10);
}
return 0;
}
#平衡树#洛谷 1110 [ZJOI2007]报表统计的更多相关文章
- BZOJ1058或洛谷1110 [ZJOI2007]报表统计
BZOJ原题链接 洛谷原题链接 STL 本题可以直接使用\(\mathtt{STL\ multiset}\)水过去. 因为本题插入数的操作实际上就是将原数列分为\(n\)段,在每一段的末尾插入数,所以 ...
- 洛谷.1110.[ZJOI2007]报表统计(Splay Heap)
题目链接 附纯SplayTLE代码及主要思路: /* 可以看做序列有n段,Insert是每次在每一段最后插入一个元素 只有插入,没有删除,所以插入一个元素对于询问1影响的只有该元素与前边一个元素(同段 ...
- 洛谷.1110.[ZJOI2007]报表统计(Multiset Heap)
题目链接 主要思路 /* 对于询问1,用堆代替multiset/Splay 对于询问2,multiset 1.注意哨兵元素 2.注意multiset中删除时是删除某元素的一个位置,而不是这个元素!这个 ...
- 洛谷.1110.[ZJOI2007]报表统计(Multiset)
题目链接 主要思路 /* 其实只需要multiset即可 对于询问1,删除.插入差值,输出最小元素 对于询问2,插入后用前驱后继更新 1.注意哨兵元素 2.注意multiset中删除时是删除某元素的一 ...
- 洛谷 P1110 [ZJOI2007]报表统计 解题报告
P1110 [ZJOI2007]报表统计 题目描述 \(Q\)的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小\(Q\)希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细 ...
- 2018.11.09 洛谷P1110 [ZJOI2007]报表统计(multiset)
传送门 sb题. 直接用两个multisetmultisetmultiset维护相邻两个数的差值和所有数的前驱后继. 插入一个数的时候更新一下就行了. 代码: #include<bits/std ...
- bzoj P1058 [ZJOI2007]报表统计——solution
1058: [ZJOI2007]报表统计 Time Limit: 15 Sec Memory Limit: 162 MB Submit: 4099 Solved: 1390 [Submit][St ...
- 【BZOJ1058】[ZJOI2007]报表统计 STL
[BZOJ1058][ZJOI2007]报表统计 Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一.经 ...
- [ZJOI2007]报表统计(splay,堆)
[ZJOI2007]报表统计(luogu) Description 题目描述 Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. ...
- bzoj1058: [ZJOI2007]报表统计
set.操作:insert(u,v)在u后面插入v,若u后面已插入过,在插入过的后面插入.mingap求出序列两两之间差值的最小值.minsortgap求出排序后的序列两两之间的最小值.用multis ...
随机推荐
- Python嵌套绘图并为条形图添加自定义标注
论文绘图时经常需要多图嵌套,正好最近绘图用到了,记录一下使用Python实现多图嵌套的过程. 首先,实现 Seaborn 分别绘制折线图和柱状图. '''绘制折线图''' import seaborn ...
- 如何优化好UITableView,值得思考
如果你觉得 UITableViewDelegate 和 UITableViewDataSource 这两个协议中有大量方法每次都是复制粘贴,实现起来大同小异:如果你觉得发起网络请求并解析数据需要一大段 ...
- Python实现snap:对齐多张遥感影像的空间范围
本文介绍基于Python中ArcPy模块,实现基于栅格图像批量裁剪栅格图像,同时对齐各个栅格图像的空间范围,统一其各自行数与列数的方法. 首先明确一下我们的需求.现有某一地区的多张栅格遥感影像 ...
- C++ STL 容器-array类型
C++ STL 容器-array类型 array是C++11STL封装的数组,内存分配在栈中stack,绝对不会重新分配,随机访问 创建和初始化 // 下面的等同于int a[10]; std::ar ...
- ui转py文件
ui文件转py文件并且使用 简单做一个笔记,以后忘了回来看看 转换 在QT Designer中创建完ui文件后,回到pycharm中,右键点击ui文件,选择pyuic 完成后获得了和ui文件同名的py ...
- 使用Kubernetes搭建带有ik分词的Elasticsearch集群
创建好带有Ik分词的es镜像,并上传到镜像仓库中,创建镜像可参考链接中的文档 https://www.cnblogs.com/hi-lijq/p/16895206.html 编写es_cluster- ...
- Linux 系统编程从入门到进阶 学习指南
引言 大家好,我是小康 ,今天我们来学习一下 Linux 系统编程相关的知识.Linux 系统编程是连接高级语言和硬件的桥梁,它对深入理解计算机系统至关重要.无论你是打算构建高性能服务器还是开发嵌入式 ...
- WAF和IPS的区别
简介 Web应用防火墙WAF(Web Application Firewall)和入侵防御系统IPS(Intrusion Prevention System)是网络安全领域中常见的两种安全解决方案,它 ...
- Vue mixin 永远不要用!! 极品垃圾,后期维护就剩骂街了~!!
为什么 Vue mixin 永远不要用!! 极品垃圾,后期维护就剩骂街了~!! vscode 没有自动跳转 自己维护下看看,重构的时候,还得整个复写,相当于整个软件重写 F!!!
- 摆脱鼠标系列 - vscode - 页内 Ctrl + F 搜索完 回车下一个,选到后按 Esc退回到编辑状态
为什么 这个很基础,但是没有细细整理 摆脱鼠标系列 - vscode - 页内 Ctrl + F 搜索完 回车下一个,选到后按 Esc退回到编辑状态 之前还找了个快捷键 Alt + Enter,发现冲 ...