题目链接

比较简单的一道平衡树题。

第三个操作可以直接用map完成(加进去一个数只会让答案变小,于是与它的前面后面一个数做差更新答案即可),只考虑前两个操作。

·维护区间内的最大最小值,以及区间相邻两数最小差值。

·对于insert x k ,相当于在x+1前插入k,再用一个树状数组维护原数组中的每个数在现在的数组中是第几个,这个操作相当于对 x+1 ~ n 的排名全部加了1。

复杂度O(nlogn) ,常数略大...

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<vector>
#include<algorithm>
#include<queue>
#include<cmath>
#include<stack>
#include<map>
#include<cassert>
#define P puts("lala")
#define cp cerr<<"lala"<<endl
#define ln putchar('\n')
#define sp putchar(' ')
#define pb push_back
#define pf push_front
#define fi first
#define se second
#define mkp make_pair
using namespace std;
typedef pair<int,int> pii;
inline void read(int &re)
{
char ch=getchar();int g=1;
while(ch<'0'||ch>'9') {if(ch=='-')g=-1;ch=getchar();}
re=0;
while(ch<='9'&&ch>='0') re=(re<<1)+(re<<3)+(ch^48),ch=getchar();
re*=g;
}
typedef long long ll;
inline void read(ll &re)
{
char ch=getchar();ll g=1;
while(ch<'0'||ch>'9') {if(ch=='-')g=-1;ch=getchar();}
re=0;
while(ch<='9'&&ch>='0') re=(re<<1)+(re<<3)+ch-48ll,ch=getchar();
re*=g;
} const int N=500050;
const int inf=0x3f3f3f3f;
map<int,int>mp;
map<int,int>::iterator it,it1; int dv[N],n,m;
inline void add(int x,int k)
{
for(;x<=n;x+=(x&-x)) dv[x]+=k;
}
inline int ask(int x)
{
int sum=0;
for(;x>0;x-=(x&-x)) sum+=dv[x];
return sum;
} int key[N<<1],mind[N<<1],ch[N<<1][2],fa[N<<1],pre[N<<1],nex[N<<1];
int a[N],sz,root,siz[N<<1]; inline void up(int o)
{
mind[o]=min(mind[ch[o][0]],mind[ch[o][1]]);
pre[o]=key[o];nex[o]=key[o];
siz[o]=1;
if(ch[o][0])
{
mind[o]=min(mind[o],abs(key[o]-nex[ch[o][0]]));
pre[o]=pre[ch[o][0]];
siz[o]+=siz[ch[o][0]];
}
if(ch[o][1])
{
mind[o]=min(mind[o],abs(key[o]-pre[ch[o][1]]));
nex[o]=nex[ch[o][1]];
siz[o]+=siz[ch[o][1]];
}
} void build(int &o,int l,int r)
{
if(l>r) return ;
o=++sz;
int mid=l+r>>1;
key[o]=a[mid];
siz[o]=1;
pre[o]=a[mid];nex[o]=a[mid];
mind[o]=inf;
if(l==r) return ;
build(ch[o][0],l,mid-1);build(ch[o][1],mid+1,r);
fa[ch[o][0]]=o;fa[ch[o][1]]=o;
up(o);
} inline bool ge(int x){return ch[fa[x]][1]==x;}
inline void rotate(int x)
{
int f=fa[x],g=fa[f],wh=ge(x);
ch[f][wh]=ch[x][wh^1];fa[ch[f][wh]]=f;
ch[x][wh^1]=f;fa[f]=x;
fa[x]=g;
if(g) ch[g][ch[g][1]==f]=x;
up(f);up(x);
}
void splay(int x)
{
for(int f;f=fa[x];rotate(x)) if(fa[f]) rotate(ge(x)==ge(f)?f:x);
root=x;
}
int find(int k)
{
//assert(k<=siz[root]);
//assert(k>=1);
int x=root;
while(1)
{
if(k<=siz[ch[x][0]]) x=ch[x][0];
else
{
k-=siz[ch[x][0]];
if(k<=1) return x;
k--;
x=ch[x][1];
}
}
} void inspre(int k)
{
int x=ch[root][0];
while(ch[x][1]) x=ch[x][1];
ch[x][1]=++sz;siz[sz]=1;
pre[sz]=k;key[sz]=k;nex[sz]=k;
fa[sz]=x;mind[sz]=inf;
up(x);
splay(sz);
} char in[50];
int main()
{
#ifndef ONLINE_JUDGE
freopen("1.in","r",stdin);freopen("1.out","w",stdout);
#endif
int i,j,opt,T;
mind[0]=inf;
read(n);read(m);
for(i=1;i<=n;++i) add(i,1);
for(i=1;i<=n;++i) read(a[i]),mp[a[i]]++;
build(root,1,n);
int minn=inf;
for(it=mp.begin();it!=mp.end();++it)
{
it1=it;
it1++;
if(it1!=mp.end()) minn=min(minn,abs( (it->fi)-(it1->fi) ));
if((it->second)>1) minn=0;
}
siz[0]=0;
for(int cas=1;cas<=m;++cas)
{
scanf("%s",in);
if(in[0]=='I')
{
int x,k;read(x);read(k);
//cerr<<cas<<endl;
if(x+1>n)
{
int rt=find(siz[root]);
splay(rt);
root=++sz;
ch[sz][0]=rt;
fa[rt]=sz;
key[sz]=k;mind[sz]=inf;
up(sz);
}
else
{
int rt=find(ask(x+1));
splay(rt);
//cout<<siz[root]<<endl;
inspre(k);
}
mp[k]++;
it=mp.find(k);
if((it->se)>1) minn=0;
else
{
it1=it;
if(it1!=mp.begin())
{
it1--;
minn=min(minn,abs((it1->fi)-k));
}
it++;
if(it!=mp.end()) minn=min(minn,abs((it->fi)-k));
}
add(x+1,1);
}
else if(in[4]=='G') printf("%d\n",mind[root]);
else if(in[4]=='S') printf("%d\n",minn);
}
return 0;
}
/* */

ZJOI2007报表统计的更多相关文章

  1. bzoj1058: [ZJOI2007]报表统计

    set.操作:insert(u,v)在u后面插入v,若u后面已插入过,在插入过的后面插入.mingap求出序列两两之间差值的最小值.minsortgap求出排序后的序列两两之间的最小值.用multis ...

  2. BZOJ 1058: [ZJOI2007]报表统计( 链表 + set )

    这种题用数据结构怎么写都能AC吧...按1~N弄个链表然后每次插入时就更新答案, 用set维护就可以了... --------------------------------------------- ...

  3. [补档][ZJOI2007] 报表统计

    [ZJOI2007] 报表统计 题目 传送门 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细观察,小Q发现统计一 ...

  4. BZOJ_1058_[ZJOI2007]报表统计_STL

    BZOJ_1058_[ZJOI2007]报表统计_STL Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工 作,作为她的生日礼 ...

  5. bzoj 1058: [ZJOI2007]报表统计 (Treap)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1058 题面; 1058: [ZJOI2007]报表统计 Time Limit: 15 Sec ...

  6. 洛谷 P1110 [ZJOI2007]报表统计 解题报告

    P1110 [ZJOI2007]报表统计 题目描述 \(Q\)的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小\(Q\)希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细 ...

  7. bzoj P1058 [ZJOI2007]报表统计——solution

    1058: [ZJOI2007]报表统计 Time Limit: 15 Sec  Memory Limit: 162 MB Submit: 4099  Solved: 1390 [Submit][St ...

  8. 【BZOJ1058】[ZJOI2007]报表统计 STL

    [BZOJ1058][ZJOI2007]报表统计 Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一.经 ...

  9. [ZJOI2007]报表统计(splay,堆)

    [ZJOI2007]报表统计(luogu) Description 题目描述 Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. ...

  10. 1058: [ZJOI2007]报表统计 - BZOJ

    Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一.经过仔细观察,小Q发现统计一张报表实际上是维护一个非 ...

随机推荐

  1. 如何在本地配置lemonlime和使用lemonlime测试交互题

    如何在本地配置\(lemonlime\)和使用\(lemonlime\)测试交互题 \(lemonlime\)下载地址链接,提取码ae3z 点开\(lemonlime.exe\)然后编译器选择\(gc ...

  2. 蔚来杯2022牛客暑期多校训练营7 CFGJ

    比赛链接 C 题解 方法一 知识点:思维. 先统计没有出现的数,每个都可以随便放,所以作为补位用的. 将原数组左移一位作为预定的答案数组,然后开始检查.如果和原数组一样,则用补位数字填充,如果不一样就 ...

  3. 完整代码:AgileFontSet迅捷字体设置程序

    AgileFontSet用于快捷设置Windows系统字体和桌面图标间距,介绍参见:https://www.cnblogs.com/ybmj/p/11340105.html .这里提供AgileFon ...

  4. CF360E Levko and Game(贪心)

    这题贪心停水的,找\(dis1<=dis2\)的点往歇斯底里地砍,砍到没法砍就是. 写博客是为了记录下遇到的神奇bug #include <iostream> #include &l ...

  5. 管理 MongoDB 用户和权限

    创建用户 创建用户的函数是:db.createUser(). 创建用户时,需要为该用户添加权限.可添加的权限以及说明: 权限 作用 read 允许用户读取指定数据库. readWrite 允许用户读写 ...

  6. Docke 搭建 apache2 + php8 + MySQL8 环境

    Docker 安装 执行 Docker 安装命令 curl -fsSL https://get.docker.com/ | sh 启动 Docker 服务 sudo service docker st ...

  7. QQ高级功能

    本篇文章为微信公众号:酿俗 教学内容请跟着小编一起探索吧! 第一步解锁微信豆影藏内容 随后下载需要的材料,注意!手机可能会提示有病毒!这里使用这些功能报病毒很正常 其实并没有病毒只是手机厂商的安全系统 ...

  8. Python入门系列(一)安装环境

    python是什么 python是一门很受欢迎的语言,除了不能生孩子以外,其它都可以做. 它擅长的领域是脚本工具和科学数据这一块,比如大数据,数据分析什么的. python安装 为了演示和验证教程可用 ...

  9. 第四十一篇:Vue生命周期(二)

    好家伙,书接上回 上图:(Vue官网中Vue实例图片的下半张) 以下为解释: 5.1.1. mounted执行完后,表示整个Vue实例已经初始化完毕了; 此时,组件已经脱离了创建阶段;进入到运行阶段 ...

  10. 综合布线 子网掩码 IP地址 子网划分

    1.1 地址协议 ipv4 :目前主流的协议 2. ipv6 :fe80::fe7:ca03:81f:2887 2 128 IANA(The Internet Assigned Numbers Aut ...