【BZOJ1058】[ZJOI2007]报表统计 STL
【BZOJ1058】[ZJOI2007]报表统计
Description
Input
Output
对于每一个“MIN_GAP”和“MIN_SORT_GAP”命令,输出一行答案即可。
Sample Input
5 3 1
INSERT 2 9
MIN_SORT_GAP
INSERT 2 6
MIN_GAP
MIN_SORT_GAP
Sample Output
2
1
HINT
N , M ≤500000 对于所有的数据,序列内的整数不超过5*10^8。
题解:头一次感觉STL没有平衡树好写~
我们需要维护两个multiset m1,m2,m1维护的是整个序列中的数,m2维护的是所有相邻两个数的差值。还需要维护一个堆,维护所有相邻两个数的差值的最小值。还要维护一个变量,代表所有排序后相邻两个数的差值。
我们发现,对于每一次操作,需要知道的只有当前位置的最后一个数和下一个位置的第一个数,所以只需要维护每个位置的第一个数和最后一个数就行了。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <set>
#include <queue>
using namespace std;
const int maxn=500010;
multiset<int> m1,m2,m3;
multiset<int>::iterator it;
priority_queue<int> p1;
int n,m,p2;
int L[maxn],R[maxn];
char str[20];
int abs(int x)
{
return x>0?x:-x;
}
int rd()
{
int ret=0,f=1; char gc=getchar();
while(gc<'0'||gc>'9') {if(gc=='-')f=-f; gc=getchar();}
while(gc>='0'&&gc<='9') ret=ret*10+gc-'0',gc=getchar();
return ret*f;
}
int main()
{
n=rd(),m=rd(),p2=1<<30;
int i,j,a,b,c;
for(i=1;i<=n;i++) L[i]=R[i]=rd(),m1.insert(L[i]);
for(i=2;i<=n;i++)
{
if(m2.find(abs(L[i]-L[i-1]))==m2.end()) p1.push(-abs(L[i]-L[i-1]));
m2.insert(abs(L[i]-L[i-1]));
}
for(it=m1.begin(),i=*it,++it;it!=m1.end();it++)
p2=min(p2,(*it)-i),i=*it;
for(i=1;i<=m;i++)
{
scanf("%s",str);
if(str[0]=='I')
{
a=rd(),b=rd();
if(a!=n)
{
m2.erase(m2.find(abs(L[a+1]-R[a])));
if(m2.find(abs(L[a+1]-b))==m2.end()) p1.push(-abs(L[a+1]-b));
m2.insert(abs(L[a+1]-b));
}
if(m2.find(abs(b-R[a]))==m2.end()) p1.push(-abs(b-R[a]));
m2.insert(abs(b-R[a]));
it=m1.lower_bound(b);
if(it!=m1.end()) p2=min(p2,(*it)-b);
if(it!=m1.begin()) it--,p2=min(p2,b-(*it));
m1.insert(b),R[a]=b;
}
if(str[4]=='G')
{
while(m2.find(-p1.top())==m2.end()) p1.pop();
printf("%d\n",-p1.top());
}
if(str[4]=='S') printf("%d\n",p2);
}
return 0;
}
【BZOJ1058】[ZJOI2007]报表统计 STL的更多相关文章
- [bzoj1058][ZJOI2007][报表统计] (STL)
Description 小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工 作,作为她的生日礼物之一.经过仔细观察,小Q发现统计一张报表实际上是维护一个 ...
- bzoj1058: [ZJOI2007]报表统计 stl xjbg
小Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小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维护就可以了... --------------------------------------------- ...
随机推荐
- Java Volatile keyword
Volatile修饰的成员变量在每次被线程訪问时,都强迫从主内存中重读该成员变量的值.并且,当成员变量发生变化时,强迫线程将变化值回写到主内存.这样在不论什么时刻,两个不同的线程总是看到某个成员变量的 ...
- hibernate学习系列-----(7)hibernate对集合属性的操作之List集合篇
今天要写的内容其实不多,本打算将hibernate对集合的操作的内容直接归结为一篇的,但想一想,还是分开写的比较好,毕竟前面的已经发布出去来了,废话不多说,开始吧! 依旧新建一个StudentList ...
- mac打开所有软件源
sudo spctl --master-disable
- Unity 提取游戏资源之ktx转换
http://blog.csdn.net/akof1314/article/details/38022263 从雨松的博文<Unity3D研究院之mac上从.ipa中提取unity3D游戏资源( ...
- Github——Git设置及GitHub的使用
把github上的help. First : 安装:ubuntu 下,终端输入命令: sudo apt-get install git-core git-gui git-doc Next : 设置SS ...
- jsp+servlet实现文件下载
下载 1. 下载就是向客户端响应字节数据! 原来我们响应的都是html的字符数据! 把一个文件变成字节数组,使用response.getOutputStream()来各应给浏览器!!! 2. 下载的要 ...
- 百度MUX:APP动效之美需内外兼修
移动互联网时代已经到来.APP已如天空的繁星.数也数不清.随着手机硬件的不断升级,实现炫酷且流畅的动效不再是遥远的梦想.假设你是APP达人,喜欢试用各种APP,你肯定会发现越来越多的APP開始动效化. ...
- 【BIEE】14_开发流程介绍
以上是BIEE开发的流程图,通过流程图我们可以看出在BIEE中存在以下主要内容: 仪表盘 仪表盘页 分析 仪表盘提示 主题区域 Catalog RPD 以下是一些文件以及资料库存储路径 资料库存储路径 ...
- QtAndroid具体解释(6):集成信鸽推送
推送是我们开发移动应用经经常使用到的功能,Qt on Android 应用也会用到,之前也有朋友问过,这次我们来看看怎么在 Qt on Android 应用中来集成来自腾讯的信鸽推送. 有关信鸽的 S ...
- PHP-深入理解Opcode缓存
1.什么是opcode缓存? 当解释器完成对脚本代码的分析后,便将它们生成可以直接运行的中间代码,也称为操作码(Operate Code,opcode).Opcode cache的目地是避免重复编译, ...