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

OIER公司是一家大型专业化软件公司,有着数以万计的员工。作为一名出纳员,我的任务之一便是统计每位员工的工资。这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资。如果他心情好,就可能把每位员工的工资加上一个相同的量。反之,如果心情不好,就可能把他们的工资扣除一个相同的量。我真不知道除了调工资他还做什么其它事情。 工资的频繁调整很让员工反感,尤其是集体扣除工资的时候,一旦某位员工发现自己的工资已经低于了合同规定的工资下界,他就会立刻气愤地离开公司,并且再也不会回来了。每位员工的工资下界都是统一规定的。每当一个人离开公司,我就要从电脑中把他的工资档案删去,同样,每当公司招聘了一位新员工,我就得为他新建一个工资档案。 老板经常到我这边来询问工资情况,他并不问具体某位员工的工资情况,而是问现在工资第k多的员工拿多少工资。每当这时,我就不得不对数万个员工进行一次漫长的排序,然后告诉他答案。 好了,现在你已经对我的工作了解不少了。正如你猜的那样,我想请你编一个工资统计程序。怎么样,不是很困难吧?

Input

Output

输出文件的行数为F命令的条数加一。 对于每条F命令,你的程序要输出一行,仅包含一个整数,为当前工资第k多的员工所拿的工资数,如果k大于目前员工的数目,则输出-1。 输出文件的最后一行包含一个整数,为离开公司的员工的总数。

Sample Input

9 10
I 60
I 70
S 50
F 2
I 30
S 15
A 5
F 1
F 2

Sample Output

10
20
-1
2

HINT

I命令的条数不超过100000
A命令和S命令的总条数不超过100
F命令的条数不超过100000
每次工资调整的调整量不超过1000
新员工的工资不超过100000

Source

 

[Submit][Status]

HOME Back


解析:

这是一道数据结构题,据说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)的更多相关文章

  1. bzoj 1503: [NOI2004]郁闷的出纳员 Treap

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 6263  Solved: 2190[Submit][Statu ...

  2. BZOJ 1503: [NOI2004]郁闷的出纳员

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 10526  Solved: 3685[Submit][Stat ...

  3. BZOJ 1503: [NOI2004]郁闷的出纳员 splay

    1503: [NOI2004]郁闷的出纳员 Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作 ...

  4. bzoj 1503: [NOI2004]郁闷的出纳员 -- 权值线段树

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MB Description OIER公司是一家大型专业化软件公司,有着数以万计的员 ...

  5. (WA)BZOJ 1503: [NOI2004]郁闷的出纳员

    二次联通门 : BZOJ 1503: [NOI2004]郁闷的出纳员 /* BZOJ 1503: [NOI2004]郁闷的出纳员 考虑这样一个事实 无论是加或减 都是针对全体人员的 那么只需要记录一个 ...

  6. 【BZOJ】1503: [NOI2004]郁闷的出纳员(Splay)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1503 这题没有看题解就1a了-好开心,, 其实后面去看题解发现他们的都很麻烦,其实有种很简单的做法: ...

  7. 1503. [NOI2004]郁闷的出纳员【平衡树-splay】

    Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的 工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经 ...

  8. 1503: [NOI2004]郁闷的出纳员

    Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 13723  Solved: 4989[Submit][Status][Discuss] Descripti ...

  9. bzoj1503 [NOI2004]郁闷的出纳员(名次树+懒惰标记)

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 8705  Solved: 3027[Submit][Statu ...

随机推荐

  1. capwap学习笔记——初识capwap(四)

    2.5.7 CAPWAP传输机制 WTP和AC之间使用标准的UDP客户端/服务器模式来建立通讯. CAPWAP协议支持UDP和UDP-Lite [RFC3828]. ¢ 在IPv4上,CAPWAP控制 ...

  2. assetbundle 对自定义shader的打包

    http://docs.unity3d.com/Manual/managingassetdependencies.html Managing asset dependencies   Any give ...

  3. [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 ...

  4. OpenGL ES3.0

    到今天,喜欢上了非常酷的图片处理和游戏,经了解,大部分都要使用opengl es,所以准备开始学习,然后深入学习cocos2d,GPUImage.平台为IOS OpenGL ES OpenGL ES ...

  5. Android 高级 Jackson Marshalling(serialize)/Unmarshalling(deserialize)

    本文内容 高级 Jackson Marshalling 只序列化符合自定义标准的字段 把 Enums 序列化成 JSON 对象 JsonMappingException(没有找到类的序列化器) Jac ...

  6. PHPUnit单元测试

    单元测试 PHPUnit <?php /** * 定义一个用来被测试的类RemoteConnect * @author json * */ class RemoteConnect{ public ...

  7. JQuery 之 在数据加载完成后才自动执行函数

    数据加载完成执行: $(window).load(function(){ ... }); 进入页就执行,不论等数据是否加载完成: $(document).ready(function(){ ... } ...

  8. 高级NUMA参数

    Advanced NUMA Attributes You can use the advanced NUMA attributes to customize NUMA usage. Attribute ...

  9. NUMA总结。

    vsphere 5.1性能最佳实践http://www.vmware.com/pdf/Perf_Best_Practices_vSphere5.1.pdf vNUMA 要求:硬件版本8以上. 1.整个 ...

  10. DbScopeFactory

    using (var db = DbScopeFactory.Create()) { //这里修改数据 db.SaveChanges(); }