【BZOJ 1503】[NOI2004]郁闷的出纳员

时间:2022-09-05 08:53:24

【链接】 我是链接,点我呀:)

【题意】

在这里输入题意

【题解】

因为所有人工资同时递减。
所以可以设置一个变化值delta.
然后每个人的初始值为k
则把k-delta加入伸展树中。
会发现delta变化之后。
伸展树中每个人的工资就仍然是原先的值+delta

比如

I 2000

delta = 100

则会插入一个1900到伸展树中。

然后delta的值可能会发生变化。

但会发现1900+delta会总是和这个人的当前工资相同

(并且对于每个人都是如此

那么我们只要把min-delta插入到伸展树种。

则比他小的数字都是要离开的人

(把这个min-delta移动到根节点。

然后把它的左子树大小累加一下就好

至于找第k大。

则也是伸展树能够完成的事情。

x-delta插入

以及delta改变之后

x+delta始终是每个人的真实工资这一点很关键。

(很棒的ideal

【代码】

#include <cstdio>
#define which(x) (ch[fa[x]][1]==x)
using namespace std; int n,mi,delta; const int N = 1e5 + 200; int m,fa[N], tot, ch[N][2], root, x, siz[N],value[N]; void push_up(int x)
{
siz[x] = siz[ch[x][0]] + siz[ch[x][1]] + 1;
} int Rank(int x, int k)
{
if (siz[ch[x][0]] >= k)
return Rank(ch[x][0], k);
else
if (k == siz[ch[x][0]] + 1)
return x;
else
return Rank(ch[x][1], k - siz[ch[x][0]] - 1);
} void Rotate(int x)
{
int f = fa[x];
bool k = which(x);
ch[f][k] = ch[x][!k];
ch[x][!k] = f;
ch[fa[f]][which(f)] = x;
fa[ch[f][k]] = f;
fa[x] = fa[f];
fa[f] = x;
siz[x] = siz[f];
push_up(f);
} void Splay(int x, int g)
{
while (fa[x] != g)
{
int f = fa[x];
if (fa[f] == g)
{
Rotate(x);
break;
}
if (which(x) ^ which(f))
Rotate(x);
else
Rotate(f);
Rotate(x);
}
if (!g) root = x;
} void cr(int x,int num)
{
if (!x){
root = ++tot;
siz[tot] = 1;
value[tot] = num;
return;
}
if (ch[x][num>value[x]]==0){
ch[x][num>value[x]] = ++tot;
value[tot] = num;
fa[tot] = x;
siz[tot] = 1;
}else
cr(ch[x][num>value[x]],num);
push_up(x);
} int main()
{
//freopen("D:\\rush.txt","r",stdin);
long long ans = 0; scanf("%d%d",&n,&mi);
for (int i = 1;i <= n;i++){
int k;
char s[5];
scanf("%s",s);
if (s[0]=='I'){
scanf("%d",&k);
if (k<mi) continue;
cr(root,k-delta);
Splay(tot,0);
}else if (s[0]=='A'){
scanf("%d",&k);
delta+=k;
}else if (s[0]=='S'){
scanf("%d",&k);
delta-=k;
cr(root,mi-delta);
Splay(tot,0);
ans+=siz[ch[tot][0]];
root = ch[tot][1];
fa[root] = 0;
}else if (s[0]=='F'){
scanf("%d",&k);
if (k>siz[root]){
printf("%d\n",-1);
}else{
int x = Rank(root,siz[root]-k+1);
Splay(x,0);
printf("%d\n",value[x]+delta);
}
}
}
printf("%lld\n",ans);
return 0;
}

【BZOJ 1503】[NOI2004]郁闷的出纳员的更多相关文章

  1. &lpar;WA&rpar;BZOJ 1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员

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

  2. BZOJ 1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员

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

  3. BZOJ 1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员 splay

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

  4. bzoj 1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员 Treap

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

  5. bzoj 1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员 -- 权值线段树

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

  6. 1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员 (SBT)

    1503: [NOI2004]郁闷的出纳员 http://www.lydsy.com/JudgeOnline/problem.php?id=1503 Time Limit: 5 Sec  Memory ...

  7. bzoj 3224 NOI2004郁闷的出纳员

    NOI2004郁闷的出纳员 2013年12月26日6,1818 输入描述 Input Description 第一行有两个非负整数n和min.n表示下面有多少条命令,min表示工资下界. 接下来的n行 ...

  8. 【BZOJ】1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员(Splay)

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

  9. 1503&period; &lbrack;NOI2004&rsqb;郁闷的出纳员【平衡树-splay】

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

  10. 1503&colon; &lbrack;NOI2004&rsqb;郁闷的出纳员

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

随机推荐

  1. jQuery学习-css、class操作、动画方法的运用、jQ操作Dom节点

    css操作(设置单个/多个样式.获取样式) //修改单个属性:括号之中直接是需要修改的样式名,值 css(name,value) //例:$("#one").css("b ...

  2. SharePoint 2013 通过审计获取文档下载次数

    1.创建一个文档库,进入库设置,找到”Information management policy settings”,点进去,如下图: 2.分别设置”Document”.”Folder”两个,如下图: ...

  3. 关于windows的service编程

    最近需要学习下windows的service编程框架,查了下msdn发现不知所云.于是谷歌之,发现了一个非常不错的文章,重点推荐讲的非常详细,深入,看完之后基本上就能很清楚windows的servic ...

  4. CUDA中的流与事件

    流:CUDA流很像CPU的线程,一个CUDA流中的操作按顺序进行,粗粒度管理多个处理单元的并发执行. 通俗的讲,流用于并行运算,比如处理同一副图,你用一个流处理左边半张图片,再用第二个流处理右边半张图 ...

  5. Nginx反向代理&plus;DNS轮询&plus;IIS7&period;5 千万PV 百万IP 双线 网站架构案例

    原文地址:http://www.jb51.net/article/31844.htm Nginx  ("engine x") 是一个高性能的 HTTP 和反向代理服务器,也是一个 ...

  6. IO流之字符流知识总结

    字符流:读写字符的 *父类是Reader和Writer 操作流程 在Java中IO操作也是有相应步骤的,以文件操作为例,主要的操作流程如下: 使用File类打开一个文件 通过字节流或字符流的子类,指 ...

  7. 【算法】Escape

    The students of the HEU are maneuvering for their military training. The red army and the blue army ...

  8. redis的repl-ping-slave-period和repl-ping-replica-period

    网上很多Redis方面的文章,会涉及到repl-ping-slave-period和repl-ping-replica-period这两个重要参数,从一些中文解释来看,意思差不多,即:SLAVE周期性 ...

  9. &lbrack; 转载 &rsqb; Java中成员变量 和局部变量

    java语言支持的变量类型 类变量:独立于方法之外的变量,用 static 修饰. 局部变量:类的方法中的变量. 实例变量(全局变量):独立于方法之外的变量,不过没有 static 修饰. publi ...

  10. MatLab 2014a编译jar包时mcc无法使用的问题

    http://blog.csdn.net/heroafei/article/details/43273373 MatLab 2014a编译jar包时mcc无法使用的问题 2015-01-29 16:5 ...