BZOJ_1503_[NOI2004]郁闷的出纳员_权值线段树
BZOJ_1503_[NOI2004]郁闷的出纳员_权值线段树
Description
Input
Output
Sample Input
I 60
I 70
S 50
F 2
I 30
S 15
A 5
F 1
F 2
Sample Output
20
-1
2
分析:
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
#define N 200050 int ls[N*18],rs[N*18],t[N*18],root=1;
int n,nowmin,add,tot=1;
char s[10];
bool tag[N*18]; void insert(int l,int r,int x,int &p){
if(!p)p=++tot;
if(l==r){
t[p]++;return ;
}
int mid=l+r>>1;
if(tag[p]){
tag[p]=0;
if(!ls[p])ls[p]=++tot;
if(!rs[p])rs[p]=++tot;
t[ls[p]]=t[rs[p]]=0;
tag[ls[p]]=tag[rs[p]]=1;
}
if(x<=mid)insert(l,mid,x,ls[p]);
else insert(mid+1,r,x,rs[p]);
t[p]=t[ls[p]]+t[rs[p]];
} void update(int l,int r,int x,int y,int &p){
if(!p)p=++tot;
if(x<=l&&y>=r){
tag[p]=1;
t[p]=0;return ;
}
int mid=l+r>>1;
if(tag[p]){
tag[p]=0;
if(!ls[p])ls[p]=++tot;
if(!rs[p])rs[p]=++tot;
t[ls[p]]=t[rs[p]]=0;
tag[ls[p]]=tag[rs[p]]=1;
}
if(x<=mid)update(l,mid,x,y,ls[p]);
if(y>mid)update(mid+1,r,x,y,rs[p]);
t[p]=t[ls[p]]+t[rs[p]];
} int getxfromrank(int l,int r,int x,int p){
if(l==r)return l;
int mid=l+r>>1;
if(tag[p]){
tag[p]=0;
if(!ls[p])ls[p]=++tot;
if(!rs[p])rs[p]=++tot;
t[ls[p]]=t[rs[p]]=0;
tag[ls[p]]=tag[rs[p]]=1;
}
if(x<=t[ls[p]])return getxfromrank(l,mid,x,ls[p]);
else return getxfromrank(mid+1,r,x-t[ls[p]],rs[p]);
} int main(){
scanf("%d%d",&n,&nowmin);
int i,j,x,now=0;
for(i=1;i<=n;i++){
scanf("%s%d",s,&x);
if(s[0]=='I'){
if(x-add<nowmin)continue;
now++;
insert(-N,N,x-add,root);
}else if(s[0]=='A'){
add+=x;
nowmin-=x;
}else if(s[0]=='S'){
add-=x;
nowmin+=x;
update(-N,N,-N,nowmin-1,root);
}else{
if(x>t[1]){
puts("-1");continue;
}
printf("%d\n",getxfromrank(-N,N,t[1]-x+1,root)+add);
}
}
printf("%d\n",now-t[1]);
}
BZOJ_1503_[NOI2004]郁闷的出纳员_权值线段树的更多相关文章
- BZOJ_2161_布娃娃_权值线段树
BZOJ_2161_布娃娃_权值线段树 Description 小时候的雨荨非常听话,是父母眼中的好孩子.在学校是老师的左右手,同学的好榜样.后来她成为艾利斯顿第二 代考神,这和小时候培养的良好素质是 ...
- BZOJ_3685_普通van Emde Boas树_权值线段树
BZOJ_3685_普通van Emde Boas树_权值线段树 Description 设计数据结构支持: 1 x 若x不存在,插入x 2 x 若x存在,删除x 3 输出当前最小值,若不存 ...
- B20J_2733_[HNOI2012]永无乡_权值线段树合并
B20J_2733_[HNOI2012]永无乡_权值线段树合并 Description:n座岛,编号从1到n,每座岛都有自己的独一无二的重要度,按照重要度可以将这n座岛排名,名次用1到 n来表示.某些 ...
- [bzoj2733][HNOI2012]永无乡_权值线段树_线段树合并
永无乡 bzoj-2733 HNOI-2012 题目大意:题目链接. 注释:略. 想法: 它的查询操作非常友善,就是一个联通块内的$k$小值. 故此我们可以考虑每个联通块建一棵权值线段树. 这样的话每 ...
- [jdoj1258]野生动物园(change by panxf)_权值线段树_组合数
人品计算 题目大意:n个数的a序列,m组询问.每次询问给出T,A,B,K.求在a序列的[A,B]的位置之内的K小值P,的$C_{T}^{P \% T} \% 10111$. 注释:每组询问保证区间只相 ...
- 3065: 带插入区间K小值_树套树_替罪羊树_权值线段树
经过周六一天,周一3个小时的晚自习,周二2个小时的疯狂debug,终于凭借自己切掉了这道树套树题. Code: #include <cstdio> #include <algorit ...
- BZOJ-1563-郁闷的出纳员(权值线段树)
偏移量要考虑清楚. #include <bits/stdc++.h> using namespace std; const int N=4e5+10; const int BASE=1e5 ...
- bzoj 1503: [NOI2004]郁闷的出纳员 -- 权值线段树
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MB Description OIER公司是一家大型专业化软件公司,有着数以万计的员 ...
- P1486 [NOI2004]郁闷的出纳员[权值线段树]
权值线段树. 我们只用维护一个人是否存在,以及他当前排名,而不关心工资的具体值,这个可以直接算. 不难发现,如果不考虑新的员工,所有员工的工资的差值是不变的. 而加进来一个新的员工时,其工资为\(x\ ...
随机推荐
- java web--DOM
Dom总结dom:文档对象模型的简称.dom的解析:与XML一样遵循同样的规范 将标记型文档解析成一棵DOM树,并将树中的内容都封装成节点对象. 如果html文档过大,同样会造成解析过慢,怎么使用sa ...
- access窗体最大化到软件大小
Private Sub Form_Load()DoCmd.ShowToolbar "Ribbon", acToolbarNo '窗体最大化,占满软件最 End Sub
- MinGW安装与使用简介
MinGW 安装与使用简介 安装方法:其实很简单,如下: Step one: 到这里下载 MinGW, 网速慢的话可能打不开, 是个外国网站 (上面的网站镜像可能 出了点问题 , 有的东西下载下来却不 ...
- MySql 动态语句
MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. MyBatis中用于实现动态SQL的元素主要有: if choose(when,otherwise) ...
- Apache 流框架 Flink,Spark Streaming,Storm对比分析(一)
本文由 网易云发布. 1.Flink架构及特性分析 Flink是个相当早的项目,开始于2008年,但只在最近才得到注意.Flink是原生的流处理系统,提供high level的API.Flink也提 ...
- mysql报错ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)
23:29:02/2017-05-03 现象描述:在Command Line Client可以登陆,但是在命令提示符cmd下登陆出错. 我最终的解决办法是: 我先去看了一下我的my.ini配置文件. ...
- java之jsp实现动态网页
动态页面,说白了,就是根据一定的信息(条件)去改变呈现给用户的内容. 而这里所提到的一定的信息,通常就是指,在一个表单中用户所输入的信息. 先来看一个我们常见的用户登录界面吧. 在这里我们可以看到一共 ...
- Learn flask in the hard way:配置环境的安装
开发用的是win10的环境. 首先确保安装了python环境,个人比较适应python2.x的代码方式,所以安装的是python2.7.10. 另外IDE还是我最喜欢的pycharm. 然后开始安装F ...
- 并查集(union-find set)与Kruskal算法
并查集 并查集处理的是集合之间的关系,即‘union' , 'find' .在这种数据类型中,N个不同元素被分成若干个组,每组是一个集合,这种集合叫做分离集合.并查集支持查找一个元素所属的集合和两个元 ...
- 常用域名记录解释:A记录、MX记录、CNAME记录、TXT记录、AAAA记录、NS记录
A记录 A记录是用来创建到IP地址的记录. A记录设置技巧 1.如果想创建不带www的记录,即ezloo.com,在主机记录中填写@或者留空,不同的注册商可能不一样. 2.创建多个域名到同一个IP,比 ...