[bzoj1058][ZJOI2007][报表统计] (STL)
Description
Input
Output
对于每一个“MIN_GAP”和“MIN_SORT_GAP”命令,输出一行答案即可。
Sample Input
INSERT
MIN_SORT_GAP
INSERT
MIN_GAP
MIN_SORT_GAP
Sample Output
HINT
N , M ≤500000 对于所有的数据,序列内的整数不超过5*10^8。
Solution
用stl优先队列维护全局数字差的最小值,用set维护两个相邻数字的差,而插入操作什么的是可以虚拟一下的
#include <set>
#include <map>
#include <queue>
#include <vector>
#include <math.h>
#include <stdio.h>
#include <string.h>
#include <algorithm>
template<typename Type> inline void Rin(Type &x)
{
x=0; int c=getchar(); bool b=0;
for(;c<48||c>57;c=getchar())
if(c==45)b=1;
for(;c>47&&c<58;c=getchar())
x=(x<<1)+(x<<3)+c-48;
if(b)x=-x;
}
using namespace std;
const int INF = 1000000000;
const int N = 5e5+10;
multiset<int> A,B;
map<int, int> H;
priority_queue<int, vector<int>, greater<int> > Q;
int n,m,Start[N],End[N];
inline void PushIn(int x)
{
int pre = *--B.lower_bound(x), next = *B.lower_bound(x);
Q.push(min(x - pre, next - x));
B.insert(x);
}
inline void PushBack(int x)
{
H[x]++;
if(H[x] == 1) A.insert(x);
}
int main()
{
Rin(n), Rin(m);
B.insert(INF), B.insert(-INF);
for(int i = 1, x; i <= n; i++)
{
Rin(x);
Start[i] = End[i] = x;
PushIn(x);
}
for(int i = 2; i <= n; i++)
PushBack(abs(Start[i] - Start[i - 1]));
for(; m; m--)
{
char ch[20]; int Pos, Num, Tmp;
scanf("%s", ch);
if(ch[0]=='I')
{
Rin(Pos), Rin(Num);
if(Pos != n)
{
Tmp=abs(End[Pos] - Start[Pos + 1]);
--H[Tmp];
if(H[Tmp]==0)A.erase(Tmp);
}
A.insert(abs(End[Pos] - Num));
PushBack(abs(Num - Start[Pos + 1]));
End[Pos] = Num;
PushIn(Num);
}
else if(ch[4]=='S')printf("%d\n", Q.top());
else printf("%d\n", *A.begin());
}
return 0;
}
[bzoj1058][ZJOI2007][报表统计] (STL)的更多相关文章
- bzoj1058: [ZJOI2007]报表统计 stl xjbg
小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一.经过仔细观察,小Q发现统计一张报表实际上是维护一个可能为负数的整数数列,并且 ...
- 【BZOJ1058】[ZJOI2007]报表统计 STL
[BZOJ1058][ZJOI2007]报表统计 Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一.经 ...
- bzoj1058: [ZJOI2007]报表统计
set.操作:insert(u,v)在u后面插入v,若u后面已插入过,在插入过的后面插入.mingap求出序列两两之间差值的最小值.minsortgap求出排序后的序列两两之间的最小值.用multis ...
- BZOJ1058: [ZJOI2007]报表统计(set)
Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 4190 Solved: 1420[Submit][Status][Discuss] Descript ...
- BZOJ1058:[ZJOI2007]报表统计(Splay,堆)
Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工 作,作为她的生日礼物之一.经过仔细观察,小Q发现统计一张报表实际上是维护一个 ...
- 【set】【multiset】bzoj1058 [ZJOI2007]报表统计
对n个位置,每个位置维护一个vector. 每次插入,可能对MIN_SORT_GAP产生的影响,只可能是 插入元素 和 它的 前驱 后继 造成的,用一个set维护(存储所有序列中的元素). 我们还得维 ...
- [补档][ZJOI2007] 报表统计
[ZJOI2007] 报表统计 题目 传送门 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细观察,小Q发现统计一 ...
- bzoj P1058 [ZJOI2007]报表统计——solution
1058: [ZJOI2007]报表统计 Time Limit: 15 Sec Memory Limit: 162 MB Submit: 4099 Solved: 1390 [Submit][St ...
- BZOJ 1058: [ZJOI2007]报表统计( 链表 + set )
这种题用数据结构怎么写都能AC吧...按1~N弄个链表然后每次插入时就更新答案, 用set维护就可以了... --------------------------------------------- ...
随机推荐
- oracle ORA-01704: string literal too long问题分析
今天使用sql在oracle直接insert update一个表时,出现ORA-01704: string literal too long的错误,我们的sql是 update mall_config ...
- Qt之界面(自定义标题栏、无边框、可移动、缩放)
效果 自定义标题栏 titleBar.h #ifndef TITLEBAR_H #define TITLEBAR_H #include <QLabel> #include <QPus ...
- [BZOJ3245]最快路线
Description 精明的小R每每开车出行总是喜欢走最快路线,而不是最短路线.很明显,每条道路的限速是小R需要考虑的关键问题.不过有一些限速标志丢失了,于是小R将不知道能开多快.不过有一个合理的方 ...
- 用java打印输出九九乘法表
package com.wh.multiplication public class Multiplication Table { public static void main(String[] a ...
- border-1px的实现(stylus)
当样式像素一定时,因手机有320px,640px等.各自的缩放比差异,所以设备显示像素就会有1Npx,2Npx.为保设计稿还原度,解决就是用media + scale. // stylus语法 bor ...
- DB buffer bussy wait 分析一例
####sample 1: DB层分析OI DB层分析OI的信息如下: 1. 异常时间段, Logical reads:/ Physical reads/ Physical write 指标都低于 ...
- snort + barnyard2如何正确读取snort.unified2格式的数据集并且入库MySQL(图文详解)
不多说,直接上干货! 为什么,要写这篇论文? 是因为,目前科研的我,正值研三,致力于网络安全.大数据.机器学习研究领域! 论文方向的需要,同时不局限于真实物理环境机器实验室的攻防环境.也不局限于真实物 ...
- WindowForm.计算器
设计计算器: 外部变量: 数字键按钮: 运算符按钮事件代码: 清零按钮 等号按钮: 思维导图:
- [ USACO 2013 OPEN ] Photo
\(\\\) Description 有一个长度为 \(n\) 的奶牛队列,奶牛颜色为黑或白. 现给出 \(m\) 个区间 \([L_i,R_i]\) ,要求:每个区间里 有且只有一只黑牛 . 问满足 ...
- 13 Red-black Trees
13 Red-black Trees Red-black trees are one of many search-tree schemes that are "balanced" ...