洛谷传送门

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

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. 【redis常用的键值操作及性能优化】

    服务端 启动redis服务 { // -a:指定密码 -h:指定主机 -p:指定端口 } //让redis 服务中断崩溃 //保存和关闭 //后台备份 //设置登录密码 //redis-benchma ...

  2. vue 数组数据更新或者对象数据更新 但是页面没有同步问题

    1,使用set函数来设置数据. 2,你可以通过 $forceUpdate 来做这件事.在数据赋值之后 就直接调用 this.$forceUpdata()

  3. tp5 数据库信息导出到excel(带图片)

    function excel_down(){ //导入谁就去查谁 $data=Db::name('order_xueyou')->select(); // 导出Exl // import(&qu ...

  4. hadoop生态搭建(3节点)-02.ssh配置

    # ssh免密码登录 # ==================================================================node1# 一路狂按回车,最终生成(id ...

  5. hdu 1394 Minimum Inversion Number(线段树)

    参考:http://blog.sina.com.cn/s/blog_691ce2b70101ldmm.html https://blog.csdn.net/wiking__acm/article/de ...

  6. react-router 4.0中跳转失灵

    在https://github.com/ReactTraining/history文档中,跳转是 用这种方法,但是,用了之后就存在这么一个问题,网址换了但是页面并没有刷新. 查了资料后,history ...

  7. 一步一步学Linq to sql(二):DataContext与实体

    DataContext DataContext类型(数据上下文)是System.Data.Linq命名空间下的重要类型,用于把查询句法翻译成SQL语句,以及把数据从数据库返回给调用方和把实体的修改写入 ...

  8. 安装cloudera manager使用mysql作为元数据库

    1.首次安装好mysql数据库后,会生成一个随机密码,使用如下办法找到: cat /var/log/mysqld.log |grep password 2.首次安装好mysql数据库后,第一次登陆进去 ...

  9. React+DvaJS 之 hook 路由权限控制

    博客 学院 下载 GitChat TinyMind 论坛 APP 问答 商城 VIP 活动 招聘 ITeye 写博客 发Chat 登录注册 原 React+DvaJS 之 hook 路由权限控制 20 ...

  10. 【C#】 反射

    [C#] 反射 目录 : http://msdn.microsoft.com/zh-cn/library/System.Reflection(v=vs.110).aspx System.Reflect ...