[luogu1110][报表统计]
思路
set+map+优先队列就可以水过去。可以发现,每插入一个元素,都会使得操作2中原来相邻的那个差值消失,然后多了两个新的差值。对于新的差值,只要直接扔到优先队列里就好了。那么删除呢。可以用map记录一下当前元素被删除了多少次。然后查询的时候将被删除的跳过即可。对于操作3,只要将插入的数都扔到set里,然后每次插入都找出当前点的前驱后继,并用ans记录下最优的。查询的时候直接输出ans即可。
为了证明自己真的有在练习平衡树,写了个splay代替set,然后跑的比set还慢2333。还可以再写一棵平衡树,来代替map+优先队列的操作。
STL代码
/*
* @Author: wxyww
* @Date: 2018-12-09 19:19:23
* @Last Modified time: 2018-12-09 19:56:45
*/
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<set>
#include<cstring>
#include<cmath>
#include<map>
#include<ctime>
#include<queue>
#include<bitset>
using namespace std;
typedef long long ll;
const int N = 1000000 + 100,INF = 1e9;
map<int,int>ma;
priority_queue<int,vector<int>,greater<int> >q;
set<int>s;
ll read() {
ll x=0,f=1;char c=getchar();
while(c<'0'||c>'9') {
if(c=='-') f=-1;
c=getchar();
}
while(c>='0'&&c<='9') {
x=x*10+c-'0';
c=getchar();
}
return x*f;
}
int a[N],lianbiao[N],now[N];
char c[20];
set<int>::iterator k1,k2;
int ans1 = INF,ans2 = INF;
int main() {
int n = read(),m = read();
memset(a,-0x3f,sizeof(a));
s.insert(-INF);s.insert(INF);
for(int i = 1;i <= n;++i) {
a[i] = read();
lianbiao[i - 1] = i;
k1 = --s.lower_bound(a[i]);k2 = s.lower_bound(a[i]);
ans2 = min(ans2,min(abs(*k1 - a[i]),abs(*k2 - a[i])));
q.push(abs(a[i] - a[i - 1]));
s.insert(a[i]);
now[i] = i;
}
while(m--) {
scanf("%s",c + 1);
if(c[1] == 'I') {
int pos = read();
a[++n] = read();
int k = now[pos];
ma[abs(a[k] - a[lianbiao[k]])]++;
q.push(abs(a[n] - a[k]));q.push(abs(a[n] - a[lianbiao[k]]));
k1 = --s.lower_bound(a[n]);k2 = s.lower_bound(a[n]);
ans2 = min(ans2,min(abs(*k1 - a[n]),abs(*k2 - a[n])));
s.insert(a[n]);
now[pos] = n;
lianbiao[n] = lianbiao[k];
lianbiao[k] = n;
}
else if(c[6] == 'A') {
int z = q.top();
while(ma[z]) {
q.pop();
ma[z]--;
z = q.top();
}
printf("%d\n",z);
}
else printf("%d\n",ans2);
}
return 0;
}
splay代码
/*
* @Author: wxyww
* @Date: 2018-12-09 16:29:51
* @Last Modified time: 2018-12-09 20:32:00
*/
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<map>
#include<queue>
#include<ctime>
#include<bitset>
using namespace std;
#define ls TR[cur].ch[0]
#define rs TR[cur].ch[1]
typedef long long ll;
const int N = 1000000 + 100,INF = 1e9;
ll read() {
ll x=0,f=1;char c=getchar();
while(c<'0'||c>'9') {
if(c=='-') f=-1;
c=getchar();
}
while(c>='0'&&c<='9') {
x=x*10+c-'0';
c=getchar();
}
return x*f;
}
struct node {
int ch[2],val,siz,pre,cnt;
}TR[N];
inline void up(int cur) {
TR[cur].siz = TR[ls].siz + TR[rs].siz + TR[cur].cnt;
}
int tot,rt;
inline int getwh(int cur) {
return TR[TR[cur].pre].ch[1] == cur;
}
inline void rotate(int cur) {
int f = getwh(cur),fa = TR[cur].pre,gr = TR[fa].pre;
TR[cur].pre = gr;
TR[gr].ch[getwh(fa)] = cur;
TR[TR[cur].ch[f ^ 1]].pre = fa;
TR[fa].ch[f] = TR[cur].ch[f ^ 1];
TR[fa].pre = cur;
TR[cur].ch[f ^ 1] = fa;
up(fa);up(cur);
}
void splay(int cur,int to) {
while(TR[cur].pre != to) {
if(TR[TR[cur].pre].pre != to) {
if(getwh(cur) == getwh(TR[cur].pre)) rotate(TR[cur].pre);
else rotate(cur);
}
rotate(cur);
}
if(!to) rt = cur;
}
void insert(int cur,int val,int father) {
if(!cur) {
cur = ++tot;
TR[cur].pre = father;
TR[cur].val = val;
TR[cur].siz = TR[cur].cnt = 1;
TR[father].ch[val > TR[father].val] = cur;
splay(cur,0);
return;
}
TR[cur].siz++;
if(val == TR[cur].val) {TR[cur].cnt++;return;}
insert(TR[cur].ch[val > TR[cur].val],val,cur);
}
inline int getpos(int val) {
int cur = rt,lst;
while(cur) {
lst = cur;
if(TR[cur].val == val) return cur;
if(val > TR[cur].val) cur = rs;
if(val < TR[cur].val) cur = ls;
}
return lst;
}
inline int pred(int val) {
int cur = getpos(val);
if(TR[cur].val <= val) return TR[cur].val;
splay(cur,0);
cur = ls;
while(rs) cur = rs;
return TR[cur].val;
}
inline int nex(int val) {
int cur = getpos(val);
if(TR[cur].val >= val) return TR[cur].val;
splay(cur,0);
cur = rs;
while(ls) cur = ls;
return TR[cur].val;
}
int a[N],lianbiao[N],now[N];
char c[20];
int ans1 = INF,ans2 = INF;
map<int,int>ma;
priority_queue<int,vector<int>,greater<int> >q;
int main() {
int n = read(),m = read();
memset(a,-0x3f,sizeof(a));
insert(rt,-INF,0);insert(rt,INF,0);
for(int i = 1;i <= n;++i) {
a[i] = read();
lianbiao[i - 1] = i;
// puts("!!");
int k1 = pred(a[i]),k2 = nex(a[i]);
ans2 = min(ans2,min(abs(k1 - a[i]),abs(k2 - a[i])));
q.push(abs(a[i] - a[i - 1]));
insert(rt,a[i],0);
now[i] = i;
}
while(m--) {
scanf("%s",c + 1);
if(c[1] == 'I') {
int pos = read();
a[++n] = read();
int k = now[pos];
ma[abs(a[k] - a[lianbiao[k]])]++;
q.push(abs(a[n] - a[k]));q.push(abs(a[n] - a[lianbiao[k]]));
int k1 = pred(a[n]),k2 = nex(a[n]);
ans2 = min(ans2,min(abs(k1 - a[n]),abs(k2 - a[n])));
insert(rt,a[n],0);
now[pos] = n;
lianbiao[n] = lianbiao[k];
lianbiao[k] = n;
}
else if(c[6] == 'A') {
int z = q.top();
while(ma[z]) {
q.pop();
ma[z]--;
z = q.top();
}
printf("%d\n",z);
}
else printf("%d\n",ans2);
}
return 0;
}
一言
积极者相信只有推动自己才能推动世界,只要推动自己就能推动世界。
[luogu1110][报表统计]的更多相关文章
- 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发现统计一 ...
- 【BZOJ1058】【ZJOI2007】报表统计(链表,堆,Splay)
[BZOJ1058][ZJOI2007]报表统计 题面 题目描述 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 ...
- 基于Fusioncharts的报表统计
先了解fusioncharts插件,fusioncharts是一款基于XML和flash的报表组件,支持Java.PHP.AngularJS等等开发语言,所以,开发出来,加入swf文件,就可以出现动态 ...
- 洛谷 P1110 [ZJOI2007]报表统计 解题报告
P1110 [ZJOI2007]报表统计 题目描述 \(Q\)的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小\(Q\)希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细 ...
- bzoj P1058 [ZJOI2007]报表统计——solution
1058: [ZJOI2007]报表统计 Time Limit: 15 Sec Memory Limit: 162 MB Submit: 4099 Solved: 1390 [Submit][St ...
随机推荐
- HTML5经典案例学习-----新元素添加文档结构
直接上代码了,大家如果发现问题了,记得提醒我哦,谢谢啦,嘻嘻 <!DOCTYPE html> <!-- 不区分大小写 --> <html lang="en&qu ...
- MySQL 字段内容区分大小写
数据由Oracle 迁入MySQL ,由于之前Oracle区分大小写,MySQL的配置使用了默认配置,导致一些数据导入失败,有的唯一键报错,冲突. 将测试过程记录在下面. 数据库版本:MySQL 5. ...
- Python:matplotlib绘制线条图
线型图是学习matplotlib绘图的最基础案例.我们来看看具体过程: 下面我们将两条曲线绘制到一个图形里: 可以看到这种方式下,两个线条共用一个坐标轴,并且自动区分颜色. plot方法的核心是 ...
- MSDN学习: 加密解密Config文件中的Sections( Encrypting and Decrypting Configuration Sections)
https://msdn.microsoft.com/en-us/library/wfc2t3az(v=vs.100).aspx https://msdn.microsoft.com/en-us/li ...
- 一、MyCat的搭建
一.什么是mycat 简单直接点就是,MyCat其实就是一个数据库的中间件!一般我们都是app直接到数据库!有了MyCat以后,就是app到MyCat然后再访问数据库. mycat是个中间件,它负责连 ...
- Windows & RabbitMQ:集群(clustering) & 高可用(HA)
描述:我们需要配置三台服务器:ServerA, ServerB, ServerC 注意事项: 所有的服务器的Erlang版本,RabbitMQ版本必须一样 服务器名大小写敏感 Step 1:安装Rab ...
- Linux环境下安装NodeJS和mongoDB
前面的话 本文将详细介绍如何下Linux环境下安装NodeJS和mongoDB NodeJS [1]使用二进制包安装 1.在官网下载Linux环境下的NodeJS安装包 2.通过xftp软件将安装包上 ...
- Express static 托管静态文件 理解
今天偶尔看了一下服务端渲染,遇到了express.static, 在以前学习webpack配置服务端渲染时,也使用express.static 中间件,两者配置不太一样,由于当时也没有认真学,所以 一 ...
- git bash 下操作文件及文件夹命令
1, cd : change directory的简写,改变目录的意思,就是切换到哪个目录下, 如 cd e:\fff 切换 E 盘下面的fff 目录. 当我们用cd 进入文件夹时,我们可以使用 通 ...
- 【数学建模】day08-数理统计III
2. 回归分析 回归分析与曲线拟合区分. 曲线拟合是,根据得到的若干有关变量的一组数据,寻找因变量与(一个或几个)自变量之间的一个函数,使这个函数对那组数据拟合得好.通常,函数的形式可以由经验.先验知 ...