传送门:https://loj.ac/problem/10145

简单的平衡树

————————————————————————————————————

  1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=1e5+10;
4 int n,minv,lk;
5 struct node
6 {
7 int val,lc,rc,siz,rd,delt;
8 }tr[maxn];
9 int cnt,root;
10 int newnode(int v)
11 {
12 tr[++cnt].val=v;
13 tr[cnt].lc=tr[cnt].rc=0;
14 tr[cnt].siz=1;
15 tr[cnt].rd=rand();
16 tr[cnt].delt=0;
17 return cnt;
18 }
19 void update(int cur)
20 {
21 tr[cur].siz=tr[tr[cur].lc].siz+tr[tr[cur].rc].siz+1;
22 }
23 void down(int cur)
24 {
25 if(!cur)return ;
26 if(tr[cur].delt)
27 {
28 tr[tr[cur].lc].val+=tr[cur].delt;
29 tr[tr[cur].rc].val+=tr[cur].delt;
30 tr[tr[cur].lc].delt+=tr[cur].delt;
31 tr[tr[cur].rc].delt+=tr[cur].delt;
32 tr[cur].delt=0;
33 }
34 }
35 int merge(int x,int y)
36 {
37 if(x*y==0)return x+y;
38 if(tr[x].rd<tr[y].rd)
39 {
40 down(x);
41 tr[x].rc=merge(tr[x].rc,y);
42 update(x);
43 return x;
44 }
45 else
46 {
47 down(y);
48 tr[y].lc=merge(x,tr[y].lc);
49 update(y);
50 return y;
51 }
52 }
53 void splitm(int cur,int v,int &x,int &y)
54 {
55 if(!cur)x=y=0;
56 else
57 {
58 if(tr[tr[cur].lc].siz+1<=v)
59 {
60 down(cur);
61 x=cur;
62 splitm(tr[cur].rc,v-tr[tr[cur].lc].siz-1,tr[cur].rc,y);
63 }
64 else
65 {
66 down(cur);
67 y=cur;
68 splitm(tr[cur].lc,v,x,tr[cur].lc);
69 }
70 update(cur);
71 }
72 }
73 void splitv(int cur,int v,int &x,int &y)
74 {
75 if(!cur)x=y=0;
76 else
77 {
78 down(cur);
79 if(tr[cur].val<=v)
80 {
81 x=cur;
82 splitv(tr[cur].rc,v,tr[cur].rc,y);
83 }
84 else
85 {
86 y=cur;
87 splitv(tr[cur].lc,v,x,tr[cur].lc);
88 }
89 update(cur);
90 }
91 }
92
93 char s[3];
94 void insert(int v)
95 {
96 if(v<minv)
97 {
98 return ;
99 }
100 int x,y;
101 splitv(root,v,x,y);
102 root=merge(merge(x,newnode(v)),y);
103 }
104 void add(int v)
105 {
106 tr[root].val+=v;
107 tr[root].delt+=v;
108 int x,y;
109 if(v<0)
110 {
111 splitv(root,minv-1,x,y);
112 lk+=tr[x].siz;
113 root=y;
114 }
115 }
116 int kth(int cur,int k)
117 {
118 while(cur)
119 {
120 down(cur);
121 if(tr[tr[cur].lc].siz+1==k)return tr[cur].val;
122 else if(tr[tr[cur].lc].siz>=k)cur=tr[cur].lc;
123 else
124 {
125 k-=tr[tr[cur].lc].siz+1;
126 cur=tr[cur].rc;
127 }
128 }
129 }
130 void find(int v)
131 {
132 if(!root || tr[root].siz<v || v<=0)
133 {
134 puts("-1");
135 return ;
136 }
137 int x,y;
138 splitm(root,v-1,x,y);
139 printf("%d\n",kth(y,1));
140 root=merge(x,y);
141 }
142 int main()
143 {
144 scanf("%d%d",&n,&minv);
145 for(int x,i=0;i<n;++i)
146 {
147 scanf("%s%d",s,&x);
148 if(s[0]=='I')insert(x);
149 else if(s[0]=='A')add(x);
150 else if(s[0]=='S')add(-x);
151 else find(tr[root].siz-x+1);
152 }
153 printf("%d\n",lk);
154 return 0;
155 }

LOJ10145郁闷的出纳员的更多相关文章

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

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

  2. [BZOJ1503][NOI2004]郁闷的出纳员

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

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

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

  4. c++之路进阶——codevs1286(郁闷的出纳员)

    1286 郁闷的出纳员 2004年NOI全国竞赛  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master       题目描述 Description OIER公司 ...

  5. 【BZOJ】【1503】 【NOI2004】郁闷的出纳员

    Splay Splay的模板题吧……妥妥的序列操作= =(好像有段时间没写过这种纯数据结构题了……) /************************************************ ...

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

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

  7. 数据结构(跳跃表):NOI 2004 郁闷的出纳员

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

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

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

  9. NOI2004 郁闷的出纳员 Splay

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

随机推荐

  1. 工具类输出当前ApplicationContext所有被装配的类

    package org.springblade.desk.utils; import org.springframework.beans.BeansException; import org.spri ...

  2. jdbc编程学习(1)

    一,背景 1996年,sun公司发布了第一版本的数据库连接(JDBC)API,使编程人员可以通过这个API接口连接到数据库,并使用结构化查询语言(SQL)完成对数据库的查找与更新.JDBC自此成为Ja ...

  3. AWS中国区的那些“坑”

    前言 最近做的一个项目是要把公司在国外已经上线的一个物联网的项目移植到AWS中国区来. 由于AWS属于国外云产商,在中国运营,必须符合国家的相关规定: 必须是合资公司 (AWS北京区由北京光环新网运营 ...

  4. JavaDailyReports10_11

    ********************************** 验证码 AWT Swing 1 package nanshen; 2 3 import java.awt.Container; 4 ...

  5. 表单绑定v-model

    表单控件在实际开发中是极为常见的.特别是对于用户信息的提交,需要大量的表单.Vue中使用v-model指令来实现表单元素和数据的双向绑定.此篇记录下其原理,以及当时学习时候的一些小尝试以及修饰符. v ...

  6. 漫谈JSON Web Token(JWT)

    一.背景 传统的单体应用基于cookie-session的身份验证流程一般是这样的: 用户向服务器发送账户和密码. 服务器验证账号密码成功后,相关数据(用户角色.登录时间等)都保存到当前会话中. 服务 ...

  7. 迭代器设计模式,帮你大幅提升Python性能

    大家好,我们的git专题已经更新结束了,所以开始继续给大家写一点设计模式的内容. 今天给大家介绍的设计模式非常简单,叫做iterator,也就是迭代器模式.迭代器是Python语言当中一个非常重要的内 ...

  8. 改进你的c#代码的5个技巧(一)

    亲爱的读者,在这篇文章中,我提供了一些c#编程的最佳实践. 你是否在用户输入验证中使用异常处理机制? 如果是,那么你就是那个把你的项目执行速度降低了62倍的人.你不相信我吗?等几分钟;我来教你怎么做. ...

  9. layer做阻塞式弹出层的方法

    今天遇到一个问题: layer弹出一个confirm提示窗,然后confirm还没有点击对应的按钮的时候,就已经执行了后续代码,我这里做出的判断是,是否需要进行后续操作,但是因为layer.confi ...

  10. Elastisearch在kibana下批量处理(mget和bulk)

    一.批量查询 有点:能够大大减少网络的请求次数,减少网络开销 1.自定义设置index.type以及document id,进行查询 GET /_mget { "docs":[ { ...