洛谷传送门

主要思路大概也是差不多的,对于两种询问分别用线段树与平衡树来维护。

1.MIN_SORT_GAP:显然平衡树简单操作,来一发前驱、后继即可。

2.MIN_GAP:这一个我用的是线段树:可以注意到插入元素的操作,如果是在一个元素之后反复插入,这些元素之间更新出来的最小值是不会发生改变的。只有元素与元素之间会有不断的插入而导致最小值变大。所以用线段树单点修改+维护区间min值,相邻插入值(中间不会再出现新的数字)之间可以直接暴力维护。

代码如下:

#include <bits/stdc++.h>
using namespace std;
#define INF 99999999999LL
#define maxn 2000000
#define int long long
int n, m, tot, M1 = INF, M2 = INF, a[maxn];
int b[maxn], root;
struct tree
{
int l, r, num;
}T[maxn]; struct node
{
int v, ch[], fa;
}P[maxn]; int read()
{
int x = , k = ;
char c;
c = getchar();
while(c < '' || c > '') { if(c == '-') k = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * k;
} struct Splay_Balanced_Tree
{
void rotate(int x)
{
int f = P[x].fa, gf = P[f].fa;
int k = x == P[f].ch[];
P[x].fa = gf;
if(gf) P[gf].ch[f == P[gf].ch[]] = x;
P[f].ch[k] = P[x].ch[k ^ ], P[P[x].ch[k ^ ]].fa = f;
P[f].fa = x, P[x].ch[k ^ ] = f;
} void Splay(int x, int goal)
{
while(P[x].fa != goal)
{
int f = P[x].fa, gf = P[f].fa;
if(gf != goal) (P[f].ch[] == x) ^ (P[gf].ch[] == f) ? rotate(x) : rotate(f);
rotate(x);
}
if(goal == ) root = x;
} void ins(int x)
{
int u = root, ff = ;
while(u && P[u].v != x)
{
ff = u;
u = P[u].ch[P[u].v < x];
}
if(!u)
{
u = ++ tot;
P[u].fa = ff;
if(ff) P[ff].ch[P[ff].v < x] = u;
P[u].v = x;
Splay(u, );
}
} void Find(int x)
{
int u = root;
if(!u) return;
while(P[u].v != x && P[u].ch[P[u].v < x]) u = P[u].ch[P[u].v < x];
Splay(u, );
} int next(int x, int k)
{
Find(x);
int u = root;
if(P[u].v == x) return P[u].v;
if((P[u].v < x && !k) || (P[u].v > x && k)) return P[u].v;
u = P[u].ch[k];
while(P[u].ch[k ^ ]) u = P[u].ch[k ^ ];
return P[u].v;
}
}SBT; struct Segament_Tree
{
void build(int p, int l, int r)
{
T[p].l = l, T[p].r = r;
if(l == r)
{
T[p].num = abs(a[l] - a[l - ]);
return;
}
int mid = (l + r) >> ;
build(p << , l, mid), build(p << | , mid + , r);
T[p].num = min(T[p << ].num, T[p << | ].num);
} void update(int p, int x, int num)
{
int mid = (T[p].l + T[p].r) >> ;
if(T[p].l == T[p].r)
{
T[p].num = num;
return;
}
if(x <= mid) update(p << , x, num);
else update(p << | , x, num);
T[p].num = min(T[p << ].num, T[p << | ].num);
}
}SGT; signed main()
{
n = read(), m = read();
SBT.ins(INF), SBT.ins(- INF);
a[] = a[n + ] = INF;
for(int i = ; i <= n; i ++)
{
a[i] = read();
if(i != )
{
int l = SBT.next(a[i], ), r = SBT.next(a[i], );
M2 = min(M2, min(abs(l - a[i]), abs(r - a[i])));
}
SBT.ins(a[i]);
b[i] = a[i];
}
SGT.build(, , n);
for(int i = ; i <= m; i ++)
{
string s;
cin >> s;
if(s[] == 'I')
{
int x = read(), y = read();
int l = SBT.next(y, ), r = SBT.next(y, );
M2 = min(M2, min(abs(l - y), abs(r - y)));
SBT.ins(y);
M1 = min(M1, abs(b[x] - y));
SGT.update(, x + , abs(a[x + ] - y));
b[x] = y;
}
else if(s[] == 'G') printf("%lld\n", min(M1, T[].num));
else printf("%lld\n", M2);
}
return ;
}

【题解】ZJOI2007报表统计的更多相关文章

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

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

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

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

  3. bzoj1058: [ZJOI2007]报表统计

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

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

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

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

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

  6. BZOJ_1058_[ZJOI2007]报表统计_STL

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

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

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

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

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

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

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

  10. 题解 Luogu P1110 【[ZJOI2007]报表统计】

    感谢 @cmy962085349 提供的hack数据,已经改对了. 先声明,我好像是题解里写双$fhq$ $treap$里唯一能过的...(最后两个点啊) 思路:首先看题目,$MIN_GAP_SORT ...

随机推荐

  1. 【ISIS(中间系统到中间系统)路由链路状态信息协议初识】

    ISIS单区域的基本配置 一:根据项目需求,考虑到组网的规模和条件,部署ISIS单区域的拓扑图如下: 二:配置 1:首先对RTA进行配置,在系统视图创建ISIS进程:进入ISIS配置视图,指定IS的级 ...

  2. sql语句中#{}和${}的区别

    #---将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号.如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by “111”, 如果传入的 ...

  3. PHP一些常用魔术方法

    魔术方法                          调用方法                                     作用__set                   有两个 ...

  4. elasticsearch 5.x 系列之四(索引模板的使用,详细得不要不要的)

    1,首先看一下下面这个索引模板 curl -XPUT "master:9200/_template/template_1?pretty" -H 'Content-Type: app ...

  5. 初识python 面向对象

    what the f**k!!这个知识点学不好的最大元凶就是,我还单身??? python基础(四): 面向对象的三个特点: 封装,继承,多态 类: 对象是面向对象编程的核心,在使用对象的过程中,为了 ...

  6. SapScript

    * [OPEN_FORM] SAPscript: フォーム印刷の開始 * [START_FORM] SAPscript: 書式を開始 * [WRITE_FORM] SAPscript: 書式ウィンドウ ...

  7. 初步学习pg_control文件之十二

    接前问,初步学习pg_control文件之十一,再来看下面这个 XLogRecPtr minRecoveryPoint; 看其注释: * minRecoveryPoint is updated to ...

  8. C++11中decltype的使用

    The decltype type specifier yields the type of a specified expression. The decltype type specifier, ...

  9. 深度分析如何在Hadoop中控制Map的数量(摘抄)

    很多文档中描述,Mapper的数量在默认情况下不可直接控制干预,因为Mapper的数量由输入的大小和个数决定.在默认情况下,最终input占据了多少block,就应该启动多少个Mapper.如果输入的 ...

  10. 高德API+.NET解决租房问题(新增诚信房源)

    作者:李国宝链接:https://zhuanlan.zhihu.com/p/22105008(欢迎点赞)来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 之前有小伙伴反应 ...