【权值分块】bzoj1503 [NOI2004]郁闷的出纳员
权值分块,离散化非常蛋疼,只能离散化搞……
需要支持操作:删除<=某个值得所有权值==打标记 O(sqrt(n))
码长和我的平衡树差不多……速度快3倍左右。
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstring>
using namespace std;
#define N 201001
struct Point{int v,p;}tmp[N];
bool operator < (const Point &a,const Point &b){return a.v<b.v;}
int n,m,Infu,a[N],c[N],leave,
en/*插入的权值数*/,en2/*离散化之后的权值种类数*/,ma[N];
char op[N];
int num[N],l[],CH[],r[],Num,sumv[],sum,sz,b[N],all;
bool delta[N];
inline void R(int &x){
char c=;int f=;
for(;c<''||c>'';c=getchar())if(c=='-')f=-;
for(x=;c>=''&&c<='';c=getchar())(x*=)+=(c-'');
x*=f;
}
inline void P(int x)
{
if(!x){putchar('');puts("");return;}
if(x<){putchar('-');x=-x;}Num=;
while(x>)CH[++Num]=x%,x/=;
while(Num)putchar(CH[Num--]+);puts("");
}
void makeblock()
{
sz=sqrt(en2); if(!sz) sz=;
for(sum=;sum*sz<en2;sum++)
{
l[sum]=r[sum-]+;
r[sum]=sum*sz;
for(int i=l[sum];i<=r[sum];i++) num[i]=sum;
}
l[sum]=r[sum-]+;
r[sum]=en2;
for(int i=l[sum];i<=r[sum];i++) num[i]=sum;
}
void pushdown(const int &p)
{
if(delta[p])
{
for(int i=l[p];i<=r[p];i++) b[i]=;
delta[p]=;
}
}
inline void Insert(const int &x){pushdown(num[x]); b[x]++; sumv[num[x]]++; all++;}
inline void Delete(const int &v)//删除小于等于v的所有权值
{
int used=all; pushdown(num[v]);
for(int i=v;i>=l[num[v]];i--)
{
sumv[num[i]]-=b[i];
all-=b[i];
b[i]=;
}
for(int i=num[v]-;i>=;i--) if(sumv[i])
{
delta[i]=;
all-=sumv[i];
sumv[i]=;
} leave+=(used-all);
}
inline int Kth(const int &x)
{
int cnt=;
for(int i=sum;;i--)
{
cnt+=sumv[i];
if(cnt>=x)
{
cnt-=sumv[i];
for(int j=r[i];;j--)
{cnt+=b[j]; if(cnt>=x) return j;}
}
}
}
int main()
{
R(n); R(m);
for(int i=;i<=n;i++)
{
op[i]=getchar(); R(a[i]);
if(op[i]=='I')
{
tmp[++en].v=a[i]-Infu;//为新员工消除之前工资变化的影响
tmp[en].p=en;
}
else if(op[i]=='A') Infu+=a[i];
else if(op[i]=='S')
{
Infu-=a[i];
tmp[++en].v=m-Infu-;//每次删除<=m-Infu-1的权值
tmp[en].p=en;
}
}
sort(tmp+,tmp+en+);
ma[c[tmp[].p]=++en2]=tmp[].v;
for(int i=;i<=en;i++)
{
if(tmp[i].v!=tmp[i-].v) en2++;
ma[c[tmp[i].p]=en2]=tmp[i].v;
} Infu=en=; makeblock();
for(int i=;i<=n;i++)
{
if(op[i]=='I') {en++; if(a[i]>=m) Insert(c[en]);}
else if(op[i]=='A') Infu+=a[i];
else if(op[i]=='S')
{
Infu-=a[i];
Delete(c[++en]);
}
else
{
if(a[i]>all) puts("-1");
else P(ma[Kth(a[i])]+Infu);
}
} P(leave);
return ;
}
【权值分块】bzoj1503 [NOI2004]郁闷的出纳员的更多相关文章
- [BZOJ1503][NOI2004]郁闷的出纳员
[BZOJ1503][NOI2004]郁闷的出纳员 试题描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是 ...
- bzoj1503 [NOI2004]郁闷的出纳员(名次树+懒惰标记)
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 8705 Solved: 3027[Submit][Statu ...
- [BZOJ1503][NOI2004]郁闷的出纳员 无旋Treap
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MB Description OIER公司是一家大型专业化软件公司,有着数以万计的员 ...
- bzoj1503: [NOI2004]郁闷的出纳员(伸展树)
1503: [NOI2004]郁闷的出纳员 题目:传送门 题解: 修改操作一共不超过100 直接暴力在伸展树上修改 代码: #include<cstdio> #include<cst ...
- 题解【bzoj1503 [NOI2004]郁闷的出纳员】
Description 给出一个下限 \(m\) ,要求维护以下操作 插入一个数(如果小于下限就不加) 给每个数加上一个数 给每个数减去一个数,并且删除掉 \(< m\) 的所有数 求目前第 \ ...
- [BZOJ1503] [NOI2004] 郁闷的出纳员 (treap)
Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常 ...
- BZOJ1503[NOI2004]郁闷的出纳员——treap
OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资.如果他心 ...
- [luogu1486][bzoj1503][NOI2004]郁闷的出纳员【平衡树treap】
题目描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资 ...
- 【题解】 bzoj1503: [NOI2004]郁闷的出纳员 (Splay)
bzoj1503,懒得复制,戳我戳我 Solution: 我知不知道我是那根筋抽了突然来做splay,调了起码\(3h+\),到第二天才改出来(我好菜啊),当做训练调错吧 一个裸的splay,没啥好说 ...
随机推荐
- lesson 4 再谈继承多态,抽象类和接口
再谈多态,抽象类和接口 上一次博客已经概念性的概述了继承多态,抽象类和接口,这次来具体的谈一谈他们之间的联系和需要注意的地方. 一.继承和多态:Inheritance (继承) & Polym ...
- 关于ora-12154:TNS:could not resolve the connect identifier specified
一:前言 刚刚出来实习,在公司配的电脑里面装的oracle和PL SQL时一次性就搞定,但是在自己的电脑上装了就出现这个问题,刚刚在网上看了下,所以自己就写份记载吧! 二: 在打开PLSQL Deve ...
- Lucene4.6 把时间信息写入倒排索引的Offset偏移量中,并实现按时间位置查询
有个新的技术需求,需要对Lucene4.x的源码进行扩展,把如下的有时间位置的文本写入倒排索引,为此,我扩展了一个TimeTokenizer分词器,在这个分词器里将时间信息写入 偏移量Offset中. ...
- Flink源码阅读(一)--Checkpoint触发机制
Checkpoint触发机制 Flink的checkpoint是通过定时器周期性触发的.checkpoint触发最关键的类是CheckpointCoordinator,称它为检查点协调器. org.a ...
- Idea工具点滴积累
方法参数提示: keymap里面搜索 quick document,默认是F2
- 【洛谷 P3846】 [TJOI2007]可爱的质数 (BSGS)
题目链接 \(BSGS\)模板题..不会点这里 #include <cstdio> #include <cmath> #include <map> using na ...
- swift关于is和as的解释
http://tieba.baidu.com/p/3155277323 在Swift中,类型检查使用is和as操作符来实现. is操作符用来检查一个实例是否是某种特定类型,如果是返回true,否则返回 ...
- servlet(1) - 手写第一个servlet程序 - 小易Java笔记
声明:如tomcat的安装目录为D:\Java\tomcat6,下面要根据tomcat的安装目录而定 1. 建立程序的文件结构 ==>找到tomcat的安装目录,在webapps目录下新建一个名 ...
- Linux管道符、重定向与环境变量
——<Linux就该这么学>笔记 输入输出重定向输入重定向 指把文件导入到命令中输出重定向 指把原本要输出到屏幕的数据信息写入到指定文件中 输出重定向 分为标准输出重定向和错误输出重定向 ...
- 在oracle官网上,找到我们所需版本的jdk
oracle的官网,因为都是英文,而且内容还特别多,经常的找不到历史版本的JDK. 特地,将找历史版本JDK的方法记录下来. 访问:http://www.oracle.com/technetwork/ ...