【题解】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 ...
随机推荐
- Java OOP——第三章 多态
1.多态:(polymorphism): 是具有表现多种形态能力的特征: (专业化的说法:)同一个实现接口(引用类型),使用不同的实例而执行不同的操作 指一个引用(类型)在不同情况下的多种状态.也可以 ...
- jquery点击按钮复制内容
做移动端的项目遇到一个需求要点击按钮复制dom里的内容,看了很多资料显示必须textarea或者input里的内容才能简单复制,还有就是用插件的了,最终都因为遇到各种问题放弃,最终选择了最简单的点击复 ...
- intellij IEDA 从svn拉环境到正常运行
intellij IEDA 从svn拉环境到正常运行 1.svn拉项目 在项目选择界面点击Check out from Version Control 从中选择Subversion(SVN) 2.选 ...
- Linux基础(04)、功能配置(调整防火墙、静态IP、环境变量)
目录 一.centos防火墙 二.VMware网络连接方式 2.1.连接方式:桥接.NAT.仅主机 2.2.常见问题 三.centos配置静态IP 四.环境变量 4.1.什么是环境变量 4.2.临时修 ...
- ssh 远程命令
远程拷贝文件,scp -r 的常用方法: 1.使用该命令的前提条件要求目标主机已经成功安装openssh-server 如没有安装使用 sudo apt-get install openssh-ser ...
- C++基础语言知识大汇总(不断更新!!!)
经过十天的时间,LITTLESUN做好了前期的工作,今天LITTLESUN就要在新地图里扬帆起航喽!!!(撒花) 简单的整理了一下这次启航准备好的物资.后面的航程中也会不断来补充这个小仓库哦!
- CCS实例,网页栏目
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- 怎么防止别人动态在你程序生成代码(怎么防止别人反编译你的app)
1.本地数据加密 iOS应用防反编译加密技术之一:对NSUserDefaults,sqlite存储文件数据加密,保护帐号和关键信息 2.URL编码加密 iOS应用防反编译加密技术之二:对程序中出现的U ...
- json 处理日期格式
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8") private Date createT ...
- 第二篇 Fiddler配置_浏览器&手机
什么是Fiddler? 网络项目的开发和测试中,Fiddler是强大的抓包工具,它的原理是以web代理服务器的形式进行工作的 ,可以说是非常常用的手头工具了,本文就Fiddler使用和配置进行说明. ...