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 ...
随机推荐
- scikit-learn的GBDT工具进行特征选取。
http://blog.csdn.net/w5310335/article/details/48972587 使用GBDT选取特征 2015-03-31 本文介绍如何使用scikit-learn的GB ...
- SQL Server 多条查询结果组合
假如存在下面这张表users: 1.通过sql语句返回总人数.男生总数和女生总数 select count(1) '总人数', (select count(1) from users u2 where ...
- php 传变量到 js 文件
php 传变量到 js 文件 // 传变量到js $oncj="taocanonc(".$i.",".$alli.",".$row1[mon ...
- GPUImage API文档之GPUImageContext类
GPUImageContext类,提供OpenGL ES基本环境,我们一般不会用到,所以讲的很简单. 属性 @property(readonly, nonatomic) dispatch_queue_ ...
- 如何让Fiddler可以抓取https的请求
转自:https://jingyan.baidu.com/article/00a07f38bb4f4682d028dcd2.html Fiddler通过在本机开启了一个http的代理服务器来进行htt ...
- 浅谈压缩感知(七):常见测量矩阵的MATLAB实现
1.随机高斯测量矩阵 function [ Phi ] = GaussMtx( M,N ) %GaussMtx Summary of this function goes here % Generat ...
- advertisingIdentifier
iOS 7后Mac 地址就不能用了. 不过可以用advertisingIdentifier来取,再多个project 里测试是唯一的,但如果遇到系统升级或是重刷这个就不一定能唯一了.. 这里还要加一个 ...
- Iperf是一个网络性能测试工具
http://blog.163.com/hlz_2599/blog/static/142378474201341341339314/ Iperf是一个网络性能测试工具.Iperf可以测试TCP和UDP ...
- pyqt、webkit和qt之间的关系
前言 最近在维护一个PYQT的项目,有很多不明白的地方,总结一下,共其他直接使用pyqt的人参考一下.PyQT是一个生成图形应用程序的工具包.是python语言和成功的Qt库的绑定.Qt库是这个世界上 ...
- JDK5.0 特性线程 同步装置之CountDownLatch 同步装置之CyclicBarrier 线程 BlockingQueue
来自:http://www.cnblogs.com/taven/category/475298.html import java.util.concurrent.CountDownLatch; imp ...