1503: [NOI2004]郁闷的出纳员
Time Limit: 5 Sec Memory Limit: 64 MB
Submit: 13723 Solved: 4989
[Submit][Status][Discuss]
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
#include<iostream>
#include<cstdio>
#include<cstdlib>
using namespace std; struct Treap
{
int left,right,val,rnd,size;
}tree[];
int n,m,size,root,ans,delta; void update(int k)
{
tree[k].size=tree[tree[k].left].size+tree[tree[k].right].size+;
} void lturn(int &k)
{
int t=tree[k].right;
tree[k].right=tree[t].left;
tree[t].left=k;
tree[t].size=tree[k].size;
update(k);
k=t;
} void rturn(int &k)
{
int t=tree[k].left;
tree[k].left=tree[t].right;
tree[t].right=k;
tree[t].size=tree[k].size;
update(k);
k=t;
} void insert(int &k,int x)
{
if(k==)
{
size++;k=size;
tree[k].size=;
tree[k].val=x;
tree[k].rnd=rand();
return;
}
tree[k].size++;
if(x>tree[k].val)
{
insert(tree[k].right,x);
if(tree[tree[k].right].rnd<tree[k].rnd) lturn(k);
}
else
{
insert(tree[k].left,x);
if(tree[tree[k].left].rnd<tree[k].rnd) rturn(k);
}
} int del(int &k,int x)
{
int t;
if(k==) return ;
if(tree[k].val<x)
{
t=tree[tree[k].left].size+;
k=tree[k].right;
return t+del(k,x);
}
else
{
t=del(tree[k].left,x);
tree[k].size-=t;
return t;
}
} int query(int k,int x)
{
if(tree[tree[k].left].size+==x) return tree[k].val+delta;
else if(tree[tree[k].left].size+<x) return query(tree[k].right,x-tree[tree[k].left].size-);
else return query(tree[k].left,x);
} int main()
{
scanf("%d%d",&n,&m);
while(n--)
{
char ch[];
int x;
scanf("%s %d",ch,&x);
switch(ch[])
{
case 'I':if(x>=m)insert(root,x-delta);break;
case 'A':delta+=x;break;
case 'S':delta-=x;ans+=del(root,m-delta);break;
case 'F':
if(tree[root].size>=x) printf("%d\n",query(root,tree[root].size-x+));
else printf("-1\n");
break;
}
}
printf("%d\n",ans);
return ;
}
1503: [NOI2004]郁闷的出纳员的更多相关文章
- 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]郁闷的出纳员 Treap
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 6263 Solved: 2190[Submit][Statu ...
- 1503: [NOI2004]郁闷的出纳员 (SBT)
1503: [NOI2004]郁闷的出纳员 http://www.lydsy.com/JudgeOnline/problem.php?id=1503 Time Limit: 5 Sec Memory ...
- 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公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的 工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经 ...
- bzoj1503 [NOI2004]郁闷的出纳员(名次树+懒惰标记)
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 8705 Solved: 3027[Submit][Statu ...
随机推荐
- LDAP相关操作注意事项
lc.Modify(entry.DN, new LdapModification(LdapModification.REPLACE, new LdapAttribute("mDBUseDef ...
- 查询时根据权限更改sql
import java.lang.reflect.Method; import org.apache.log4j.Logger; import org.springframework.aop.Meth ...
- jquery——样式操作
思想:同一个函数完成取值和赋值 addClass.removeClass. <!DOCTYPE html> <html lang="en"> <hea ...
- Java关键字和基础问题
1. Java关键字 1.1 extends和implements extends继承普通class或abstract(抽象)类(java单继承) implements多继承能力,实现interfac ...
- ThreadPoolExecutor线程池的keepAliveTime
keepAliveTime含义 看了很多文章觉得都不能把keepAliveTime的意思说的很明白,希望通过自己的理解把keepAliveTime说的明确一些 先引用一句我觉得相对说的比较明白的含义: ...
- 显示单位px、dip以及sp的区别
dip: Device Independent Pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA.HVGA和QVGA推荐使用这个,不依赖像素. p ...
- java-类的定义和用法
1.类的定义 public class Human{ }//每个源文件必须也只能有一个public类 class boy{ }//可以定义多个class类 class girl{ } 上面的类定义好后 ...
- Java 打印PDF文档的3种情况
以下内容归纳了通过Java程序打印PDF文档时的3种情形.即: 静默打印 显示打印对话框打印 打印PDF时自定义纸张大小 使用工具:Spire.PDF for Java Jar导入: 方法1:通过官网 ...
- bootstrap中使用modal加载kindeditor时弹出层文本框不能输入的问题
答案来自老外http://stackoverflow.com/questions/14795035/twitter-bootstrap-modal-blocks-text-input-field $( ...
- Java并发基础:线程的创建
线程的创建和管理: 1.应用Thread类显式创建.管理线程 2.应用Executor创建并管理线程. 定义任务: 无返回的任务:实现Runnable接口并编写run()方法. 有响应的任务:实现Ca ...