【bzoj1503】[NOI2004]郁闷的出纳员
1503: [NOI2004]郁闷的出纳员
Time Limit: 5 Sec Memory Limit: 64 MB
Submit: 13890 Solved: 5086
[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
题意:
你需要维护$N$个人的工资,支持以下操作:
- $I$操作:插入一个人,他的初始工资为$x$。
- $A$操作:给所有人的工资加上$x$。
- $S$操作:给所有人的工资减去$x$,如果有人的工资低于了工资下届$M$则把他删除并计入删除总人数$ans$。
- $F$操作:查询现在排名第$x$多的工资是多少,如果人数不足$x$则输出$-1$。
最后输出删除总人数$ans$。
题解:
这道题和平衡树模板的区别只在于$A$操作和$S$操作,也就是说我们需要寻求一个方法能够快速修改平衡树中所有点的点权。
注意到$A,S$操作数量很少,所以暴力修改其实就可以通过本题,但这么做也太没有梦想了吧……
我们发现所有的修改都是对于当前树中所有节点而不是一部分节点,那么是否可以维护一个$dat$表示当前树中所有点共同的增量呢?
虽然树中的点不是同时插入的,但我们如果要把这个增量强行打在新点$x$上,是不是把输入的$x$变成了$x-dat$就行了?
显然是可以的,因为$x-dat$加上现在的增量$dat$还等于$x$,并且不影响它与树中其他节点的大小关系。
那么加操作直接将$dat+x$,减操作先修改$dat$再删除所有权值$<M-dat$的点就好了。
复杂度$O(N\times log(N))$。
代码:
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio> using namespace std;
#define MAXN 100005
#define MAXM 500005
#define INF 0x7fffffff
#define ll long long struct node{
int v,f,siz,cnt,ch[];
}tr[MAXN];
int rt,tot,dat,ans; inline int read(){
int x=,f=;
char c=getchar();
for(;!isdigit(c);c=getchar())
if(c=='-')
f=-;
for(;isdigit(c);c=getchar())
x=x*+c-'';
return x*f;
} inline bool getf(int k){return tr[tr[k].f].ch[]==k;}
inline void update(int k){
tr[k].siz=tr[k].cnt;
tr[k].siz+=tr[tr[k].ch[]].siz;
tr[k].siz+=tr[tr[k].ch[]].siz;
return;
}
inline void rot(int k){
int f1=tr[k].f,f2=tr[f1].f;
bool opt=getf(k);
tr[f1].ch[opt]=tr[k].ch[opt^];
tr[tr[k].ch[opt^]].f=f1;
tr[k].ch[opt^]=f1;
tr[f1].f=k;tr[k].f=f2;
if(f2) tr[f2].ch[tr[f2].ch[]==f1]=k;
update(f1);update(k);
return;
}
inline void splay(int k){
for(int fa;fa=tr[k].f;rot(k))
if(tr[fa].f)
rot(getf(k)==getf(fa)?fa:k);
rt=k;return;
}
inline void ins(int x){
if(!rt){
rt=++tot;tr[tot].v=x;
tr[tot].siz=tr[tot].cnt=;
return;
}
int now=rt,fa=;
while(){
if(x==tr[now].v){
tr[now].cnt++;
update(now);update(fa);
splay(now);break;
}
fa=now;now=tr[now].ch[x>tr[now].v];
if(!now){
tr[++tot].v=x;tr[tot].f=fa;
tr[tot].siz=tr[tot].cnt=;
tr[fa].ch[x>tr[fa].v]=tot;
update(fa);splay(tot);
break;
}
}
return;
}
inline int qnum(int x){
int now=rt;
while(){
if(tr[tr[now].ch[]].siz<x && tr[tr[now].ch[]].siz+tr[now].cnt>=x)
return tr[now].v;
else if(tr[tr[now].ch[]].siz>=x) now=tr[now].ch[];
else x-=tr[tr[now].ch[]].siz+tr[now].cnt,now=tr[now].ch[];
}
}
inline void del(){
ans+=tr[rt].cnt+tr[tr[rt].ch[]].siz-;
rt=tr[rt].ch[];tr[rt].f=;
return;
} int main(){
//freopen("cashier2.in","r",stdin);
//freopen("cashier1.out","w",stdout);
int N=read(),M=read(),sum=;
while(N--){
char c;cin>>c;int x=read();
if(c=='I' && x>=M) sum++,ins(x-dat);
if(c=='A') dat+=x;
if(c=='S') dat-=x,ins(M-dat-),del();
if(c=='F'){
if(x>sum-ans) printf("-1\n");
else printf("%d\n",qnum(sum-ans-x+)+dat);
}
}
printf("%d\n",ans);
return ;
}
【bzoj1503】[NOI2004]郁闷的出纳员的更多相关文章
- [BZOJ1503][NOI2004]郁闷的出纳员
[BZOJ1503][NOI2004]郁闷的出纳员 试题描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是 ...
- bzoj1503 [NOI2004]郁闷的出纳员(名次树+懒惰标记)
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 8705 Solved: 3027[Submit][Statu ...
- [BZOJ1503][NOI2004]郁闷的出纳员 无旋Treap
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MB Description OIER公司是一家大型专业化软件公司,有着数以万计的员 ...
- bzoj1503: [NOI2004]郁闷的出纳员(伸展树)
1503: [NOI2004]郁闷的出纳员 题目:传送门 题解: 修改操作一共不超过100 直接暴力在伸展树上修改 代码: #include<cstdio> #include<cst ...
- [BZOJ1503] [NOI2004] 郁闷的出纳员 (treap)
Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常 ...
- BZOJ1503[NOI2004]郁闷的出纳员——treap
OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资.如果他心 ...
- [luogu1486][bzoj1503][NOI2004]郁闷的出纳员【平衡树treap】
题目描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资 ...
- BZOJ1503: [NOI2004]郁闷的出纳员(Splay)
Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的 工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经 ...
- BZOJ1503 [NOI2004]郁闷的出纳员 splay
原文链接http://www.cnblogs.com/zhouzhendong/p/8086240.html 题目传送门 - BZOJ1503 题意概括 如果某一个员工的工资低于了min,那么,他会立 ...
- 【题解】 bzoj1503: [NOI2004]郁闷的出纳员 (Splay)
bzoj1503,懒得复制,戳我戳我 Solution: 我知不知道我是那根筋抽了突然来做splay,调了起码\(3h+\),到第二天才改出来(我好菜啊),当做训练调错吧 一个裸的splay,没啥好说 ...
随机推荐
- shell之起步
初学者,先不要考虑好不好看,效率高不高!先要实现需求!需求是第一位! grep.sed.awk.三剑客! 学好shell,需要前提! 1.linux系统命令熟练 2.搞清楚正则,grep.sed.aw ...
- tkinter之canvas(画布)
画布的例子: from tkinter import * root=Tk() root.title('简易绘图') can=Canvas(root,width=400,height=300,bg='# ...
- 使用C++模拟C#的委托机制
1. [代码][C/C++]代码 //Event.h #ifndef _EVENT_H_#define _EVENT_H_class EmptyObject {};template<typen ...
- malloc和new的区别是什么?
http://zhidao.baidu.com/link?url=iUDUZeJtj1o12PvUETLlJgvAMqzky5HxGCJRGnULpsO8HdWAdjKkQqGCJ9-o-aTu8NP ...
- mysql修改初始密码
通过MySQL命令行,可以修改MySQL数据库的密码,下面就为您详细介绍该MySQL命令行,如果您感兴趣的话,不妨一看. 格式:mysqladmin -u用户名 -p旧密码 password 新密码 ...
- ACM学习历程—Hihocoder编程之美测试赛B题 大神与三位小伙伴(组合数学 )
时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给你一个m x n (1 <= m, n <= 100)的矩阵A (0<=aij<=10000),要 ...
- PowerDesigner 导出 Excel
http://www.cnblogs.com/hggc/archive/2013/10/15/3369857.html
- pow()函数的精度问题
妈蛋这个坑了我大半个小时都想不出个原因..后来看到pow的定义才想起,数据类型很重要啊.. 1.底数用常量,指数用整型 #include <stdio.h> #include <ma ...
- Linux做脚本定时任务(定时清理日志)
无论一些面试问题,还是实际应用,都会用到虚拟机的定时任务.现做定时清理日志日志做一总结. 1.查看/etc/crontab文件. linux 系统则是由 cron (crond) 这个系统服务来控制的 ...
- swfupload原理总结
1.引入js(js内动态添加上传的文件并提交表单) 2.后台处理(将图片保存) 3.调用另一个js修改前台图片的地址(改为新的图片地址)