【题解】ZJOI2007报表统计
主要思路大概也是差不多的,对于两种询问分别用线段树与平衡树来维护。
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报表统计的更多相关文章
- 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希望可以帮妈妈分担一些工作,作为她的生日礼物之一.经 ...
- bzoj1058: [ZJOI2007]报表统计
set.操作:insert(u,v)在u后面插入v,若u后面已插入过,在插入过的后面插入.mingap求出序列两两之间差值的最小值.minsortgap求出排序后的序列两两之间的最小值.用multis ...
- BZOJ 1058: [ZJOI2007]报表统计( 链表 + set )
这种题用数据结构怎么写都能AC吧...按1~N弄个链表然后每次插入时就更新答案, 用set维护就可以了... --------------------------------------------- ...
- [补档][ZJOI2007] 报表统计
[ZJOI2007] 报表统计 题目 传送门 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细观察,小Q发现统计一 ...
- BZOJ_1058_[ZJOI2007]报表统计_STL
BZOJ_1058_[ZJOI2007]报表统计_STL Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工 作,作为她的生日礼 ...
- bzoj 1058: [ZJOI2007]报表统计 (Treap)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1058 题面; 1058: [ZJOI2007]报表统计 Time Limit: 15 Sec ...
- 洛谷 P1110 [ZJOI2007]报表统计 解题报告
P1110 [ZJOI2007]报表统计 题目描述 \(Q\)的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小\(Q\)希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细 ...
- [ZJOI2007]报表统计(splay,堆)
[ZJOI2007]报表统计(luogu) Description 题目描述 Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. ...
- 题解 Luogu P1110 【[ZJOI2007]报表统计】
感谢 @cmy962085349 提供的hack数据,已经改对了. 先声明,我好像是题解里写双$fhq$ $treap$里唯一能过的...(最后两个点啊) 思路:首先看题目,$MIN_GAP_SORT ...
随机推荐
- mysql 导出数据字典
使用Navicat工具 查询: SELECT TABLE_SCHEMA AS '数据库', TABLE_NAME AS '表名', COLUMN_NAME AS '字段名', COLUMN_TYPE ...
- 【ssh服务配置】
根据项目需求,搭建好拓扑图如下: 第一种验证方式:给予密码和用户名登录 Ssh server配置: 首先在服务器上创建一个rsa加密算法的秘钥对: 对ssh服务进行开启: 创建用户的虚拟终端登录界面: ...
- 【c学习-12】
/*枚举*/ #include void enumFunction(){ enum enum_var{"a","b",1,2}; enum{"c&qu ...
- PHP判断URL地址百度是否已经收录并主动提交MIP数据
/** * PHP检测URL地址百度是否已经收录 * @param string $url 要检测的URL地址 */ function Baidu($url) { $url = 'http://www ...
- Mysql错误积累001-load data导入文件数据出现1290错误
错误出现情景 在cmd中使用mysql命令,学生信息表添加数据.使用load data方式简单批量导入数据. 准备好文本数据: xueshengxinxi.txt 文件 数据之间以tab键进行分割 ...
- while else
count = 0 while count <= 5 : count += 1 if count == 3:pass print("Loop",count) else: pr ...
- pyecharts数据分析及展示
仅仅从网上爬下数据当然是不够用的,主要还得对数据进行分析与展示,大部分人都看重薪资,但是薪资数据有的是*k/月,有的是*万/月,还有*万/年等等,就要对数据进行清理 将所有单位统一化,全部换算成统一单 ...
- 打印N个真值的所有真值组合
例:N=2 (true,true),(false,true),(true,false),(false,false) #include<stdio.h> int count=0; void ...
- Scala继承
override重写 为什么要用override关键字?因为这样更清楚,不容易出错,比如打错字了,就没覆盖成功,但是不会报错 override可以覆盖feild和method class Person ...
- 深度学习(deep learning)优化调参细节(trick)
https://blog.csdn.net/h4565445654/article/details/70477979