1503: [NOI2004]郁闷的出纳员 (SBT)
1503: [NOI2004]郁闷的出纳员
http://www.lydsy.com/JudgeOnline/problem.php?id=1503
Time Limit: 5 Sec Memory Limit: 64 MB
Submit: 4094 Solved: 1496
[Submit][Status]
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
HINT
I命令的条数不超过100000
A命令和S命令的总条数不超过100
F命令的条数不超过100000
每次工资调整的调整量不超过1000
新员工的工资不超过100000
Source
解析:
这是一道数据结构题,据说splay,AVL,SBT,Treap,线段树 ,树状数组等都可以实现
这两天刚学了SBT,虽然部分代码理解的还不是很透彻,但大致思想还是掌握了。。。
这里推荐两个学习SBT的地址:
讲解:http://www.nocow.cn/index.php/Size_Balanced_Tree
代码(包括SBT的九种操作):http://www.docin.com/p-481614045.html
这个链接也挺不错的:http://www.cnblogs.com/zhsl/p/3189901.html
#include<iostream>
#include<cstdio>
#include<cstring> using namespace std; const int N=; struct SBT{
int l,r,sz,key;
void init(){
l=r=key=;
sz=;
}
}tree[N]; int root,tot; void go_left(int &rt){
int k=tree[rt].r;
tree[rt].r=tree[k].l;
tree[k].l=rt;
tree[k].sz=tree[rt].sz;
tree[rt].sz=tree[tree[rt].l].sz+tree[tree[rt].r].sz+;
rt=k;
} void go_right(int &rt){
int k=tree[rt].l;
tree[rt].l=tree[k].r;
tree[k].r=rt;
tree[k].sz=tree[rt].sz;
tree[rt].sz=tree[tree[rt].l].sz+tree[tree[rt].r].sz+;
rt=k;
} void maintain(int &rt,int flag){
if(flag){
if(tree[tree[tree[rt].r].r].sz>tree[tree[rt].l].sz)
go_left(rt);
else if(tree[tree[tree[rt].r].l].sz>tree[tree[rt].l].sz){
go_right(tree[rt].r);
go_left(rt);
}else
return ;
}else{ //否则更新左子树
if(tree[tree[tree[rt].l].l].sz>tree[tree[rt].r].sz)
go_right(rt);
else if(tree[tree[tree[rt].l].r].sz>tree[tree[rt].r].sz){
go_left(tree[rt].l);
go_right(rt);
}else
return ;
}
maintain(tree[rt].l,false);
maintain(tree[rt].r,true);
maintain(rt,false);
maintain(rt,true);
} void insert(int &rt,int k){
if(rt==){
rt=(++tot);
tree[rt].init();
tree[rt].key=k;
}else{
tree[rt].sz++;
if(k<tree[rt].key)
insert(tree[rt].l,k);
else
insert(tree[rt].r,k);
maintain(rt,k>=tree[rt].key);
}
} void Delete(int &rt,int delay,int min_val){
if(!rt)
return ;
if(tree[rt].key+delay<min_val){
rt=tree[rt].r;
Delete(rt,delay,min_val);
}else{
Delete(tree[rt].l,delay,min_val);
tree[rt].sz=tree[tree[rt].l].sz+tree[tree[rt].r].sz+;
}
} int get_max_kth(int &rt,int k){
int tmp=tree[tree[rt].r].sz+;
if(tmp==k)
return tree[rt].key;
else if(tmp<k)
return get_max_kth(tree[rt].l,k-tmp);
return get_max_kth(tree[rt].r,k);
} int main(){ //freopen("input.txt","r",stdin); int n,min_val,delay;
while(~scanf("%d%d",&n,&min_val)){
tot=delay=root=;
char op[];
int x;
while(n--){
scanf("%s%d",op,&x);
if(op[]=='I'){
if(x<min_val)
continue;
insert(root,x-delay);
}else if(op[]=='A')
delay+=x;
else if(op[]=='F')
printf("%d\n",tree[root].sz<x?-:get_max_kth(root,x)+delay);
else{
delay-=x;
Delete(root,delay,min_val);
}
}
printf("%d\n",tot-tree[root].sz);
}
return ;
}
1503: [NOI2004]郁闷的出纳员 (SBT)的更多相关文章
- bzoj 1503: [NOI2004]郁闷的出纳员 Treap
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 6263 Solved: 2190[Submit][Statu ...
- BZOJ 1503: [NOI2004]郁闷的出纳员
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 10526 Solved: 3685[Submit][Stat ...
- BZOJ 1503: [NOI2004]郁闷的出纳员 splay
1503: [NOI2004]郁闷的出纳员 Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作 ...
- bzoj 1503: [NOI2004]郁闷的出纳员 -- 权值线段树
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MB Description OIER公司是一家大型专业化软件公司,有着数以万计的员 ...
- (WA)BZOJ 1503: [NOI2004]郁闷的出纳员
二次联通门 : BZOJ 1503: [NOI2004]郁闷的出纳员 /* BZOJ 1503: [NOI2004]郁闷的出纳员 考虑这样一个事实 无论是加或减 都是针对全体人员的 那么只需要记录一个 ...
- 【BZOJ】1503: [NOI2004]郁闷的出纳员(Splay)
http://www.lydsy.com/JudgeOnline/problem.php?id=1503 这题没有看题解就1a了-好开心,, 其实后面去看题解发现他们的都很麻烦,其实有种很简单的做法: ...
- 1503. [NOI2004]郁闷的出纳员【平衡树-splay】
Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的 工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经 ...
- 1503: [NOI2004]郁闷的出纳员
Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 13723 Solved: 4989[Submit][Status][Discuss] Descripti ...
- bzoj1503 [NOI2004]郁闷的出纳员(名次树+懒惰标记)
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 8705 Solved: 3027[Submit][Statu ...
随机推荐
- GIT 如何从另一分支合并特定的文件
是否遇到过这种情景: 您在一个分支上工作,发现该分支上的某些文件实现的功能已经在其他分支上实现了 但因为这两个分支实现不同的功能,因此不能进行简单的合并工作,但您又不想重复其他已经完成的工作 以下操作 ...
- gson ajax 数字精度丢失
ajax传输的json,gson会发生丢失,long > 15的时候会丢失0 解决方案:直接把属性为long的属性自动加上双引号成为js的字符串,这样就不会发生丢失了,ajax自动识别为字符串. ...
- Android7.0新特性,及Android N适配
新特性部分 Android 7.0 Nougat 提供新功能以提升性能.生产效率和安全性,主要新增了下面的新特性和优化: 一.新的Notification Android N 添加了很多新的notif ...
- JavaScript 从闭包可以做什么开始,将有助于理解闭包
本文内容 函数内部访问全局变量 函数外部不能直接访问局部变量 函数外部访问局部变量 保护私有成员 持久性 模块化 抽象性 闭包是 JavaScript 的重要特性,非常强大,可用于执行复杂的计算,可并 ...
- 在CentOS 7上安装Nginx服务器
下面我就我在CentOS上安装Nginx经验做简单的记录,以备后查. 1.下载nginx-release包 以CentOS 7为例,下载nginx软件包:http://nginx.org/packag ...
- javax.validation.UnexpectedTypeException: No validator could be found for constraint 'org.hibernate.validator.constraints.Length' validating type
使用hibernate validator出现上面的错误, 需要注意: @NotNull 和 @NotEmpty 和@NotBlank 区别 @NotEmpty 用在集合类上面@NotBlank 用 ...
- 电脑技巧 如何保存网页为PDF
安装Adobe Acrobat X pro(要安装版本,不要绿色版),完成之后再打印机里面可以看到添加了新的Adobe PDF打印机 对于任意的Office文档,都可以直接打印到PDF得到PDF文 ...
- 【树莓派】使用VNC远程登录树莓派的图形界面
我自己本人使用树莓派,就是ssh连接操作:但是由于实施的部分同学不熟悉Linux命令行操作,虽然之前我给搞过teamviewer方式,但是对他们而言,还是有点复杂,他们也不喜欢不熟悉用ssh,所以我尝 ...
- MDX Step by Step 读书笔记(八) - Navigating Hierarchies 层次结构导航
开篇介绍 本章主要内容包括: 解释各种不同的 MDX 导航函数的使用: Parent, Children, FirstChild, LastChild, Siblings, FirstSibling, ...
- vcenter SSO