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 ...
随机推荐
- capwap学习笔记——初识capwap(四)
2.5.7 CAPWAP传输机制 WTP和AC之间使用标准的UDP客户端/服务器模式来建立通讯. CAPWAP协议支持UDP和UDP-Lite [RFC3828]. ¢ 在IPv4上,CAPWAP控制 ...
- assetbundle 对自定义shader的打包
http://docs.unity3d.com/Manual/managingassetdependencies.html Managing asset dependencies Any give ...
- [Algorithm] Check if a binary tree is binary search tree or not
What is Binary Search Tree (BST) A binary tree in which for each node, value of all the nodes in lef ...
- OpenGL ES3.0
到今天,喜欢上了非常酷的图片处理和游戏,经了解,大部分都要使用opengl es,所以准备开始学习,然后深入学习cocos2d,GPUImage.平台为IOS OpenGL ES OpenGL ES ...
- Android 高级 Jackson Marshalling(serialize)/Unmarshalling(deserialize)
本文内容 高级 Jackson Marshalling 只序列化符合自定义标准的字段 把 Enums 序列化成 JSON 对象 JsonMappingException(没有找到类的序列化器) Jac ...
- PHPUnit单元测试
单元测试 PHPUnit <?php /** * 定义一个用来被测试的类RemoteConnect * @author json * */ class RemoteConnect{ public ...
- JQuery 之 在数据加载完成后才自动执行函数
数据加载完成执行: $(window).load(function(){ ... }); 进入页就执行,不论等数据是否加载完成: $(document).ready(function(){ ... } ...
- 高级NUMA参数
Advanced NUMA Attributes You can use the advanced NUMA attributes to customize NUMA usage. Attribute ...
- NUMA总结。
vsphere 5.1性能最佳实践http://www.vmware.com/pdf/Perf_Best_Practices_vSphere5.1.pdf vNUMA 要求:硬件版本8以上. 1.整个 ...
- DbScopeFactory
using (var db = DbScopeFactory.Create()) { //这里修改数据 db.SaveChanges(); }