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 ...
随机推荐
- ASP.NET MVC 重命名[命名空间]而导致的错误及发现的ASP.NET MVC Bug一枚
使用VS2012新建了一个Asp.net mvc5的项目,并把项目的命名空间名称更改了(Src更改为UXXXXX),然后就导致了以下错误 刚开始以后是项目的属性中的命名空间没有更改过来的问题,但我在重 ...
- 在使用Vs2013打开Vs2008的解决方案时出现了以下错误:此版本的应用程序不支持其项目类型(.csproj)
在使用Vs2013打开Vs2008的解决方案时出现了以下错误: 无法打开 因为此版本的应用程序不支持其项目类型(.csproj). 在网络上找到解决方案: 命令行或者Vs自带的命令提示符输入:deve ...
- MogileFS与FastDFS的个人见解
MogileFS与FastDFS的个人见解 六月 9, 2013 1 条评论 MogileFS & FastDFS 为两个开源分布式文件系统,都主要适用于互联网文件共享,上传,下载等功能,主要 ...
- 【转】Java抽象类与接口的区别
很多常见的面试题都会出诸如抽象类和接口有什么区别,什么情况下会使用抽象类和什么情况你会使用接口这样的问题.本文我们将仔细讨论这些话题. 在讨论它们之间的不同点之前,我们先看看抽象类.接口各自的特性. ...
- 使用SqlBulkCopy类实现导入excel表格
前言: 上篇博客介绍了SqlBulkCopy类批量操作数据库的相关操作,最后提到了可以使用这个类实现excel文件导入数据库,接下来我做简单介绍. 首先说一下思路: 把excel中的数据读出来并放入到 ...
- sqlAlchemy学习 001
研究学习主题 sqlAlchemy架构图 测试练习代码编写 连接数据库 看代码 db_config = { 'host': 'xxx.xxx.xxx.xx', 'user': 'root', 'pas ...
- ADHOC Report 配置
ADHOC Report ADHOC Report - 临时的report,随时可以去系统中按照你选择的条件打出你想看的report Add ADHOC Report --AddReport use ...
- Eclipse Java注释模板设置详解以及版权声明
网上的Eclipse注释模板,在这里稍稍整理一些比较常用的. 编辑注释模板的方法:Window->Preference->Java->Code Style->Code Temp ...
- Android学习笔记六:六大布局
六大界面布局方式包括: 线性布局(LinearLayout).帧布局(FrameLayout).表格布局(TableLayout).相对布局(RelativeLayout).绝对布局(Absolute ...
- Flash:利用Bitmapdata,ColorTransform,DrawPath,制造绚丽效果
JamesLi的文章:http://www.adobe.com/cn/devnet/actionscript/articles/silkflash-as.html 总结一下绚丽效果的核心: 1.利用一 ...