传送门: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. java中邮件通知

    // 客户信息 Tkhxx tkhxx = new Tkhxx(); try { String msg = tkhxx.toString(); MailUtil.simpleMailSend(Mail ...

  2. Fast Bokeh Effects Using Low-Rank Linear Filters

    Fast Bokeh Effects Using Low-Rank Linear Filters paper地址:https://www.researchgate.net/publication/27 ...

  3. ROS代码经验系列-- tf进行位置查询变换

    include文件: #include "tf/transform_broadcaster.h" #include "tf/transform_listener.h&qu ...

  4. 简单session实现

    简单的session校验实现 利用拦截器实现 package com.ryh.blog.intecepter; import org.springframework.core.Ordered; imp ...

  5. JVM 低延迟垃圾收集器 Shenandoah 和 ZGC

    本文部分摘自<深入理解 Java 虚拟机第三版> 概述 衡量垃圾收集器的三项指标分别是:内存占用.吞吐量和延迟.这三者共同构成一个"不可能三角",即一款优秀的收集器最多 ...

  6. docker配置mysql实现主从同步问题

    主从同步遇到 Got fatal error 1236 from master when reading data from binary log: 'Could not find first log ...

  7. java左移右移运算符详解

    在阅读源码的过程中,经常会看到这些符号<< ,>>,>>>,这些符号在Java中叫移位运算符,在写代码的过程中,虽然我们基本上不会去写这些符号,但需要明白这些 ...

  8. Miller Rabin素数检测与Pollard Rho算法

    一些前置知识可以看一下我的联赛前数学知识 如何判断一个数是否为质数 方法一:试除法 扫描\(2\sim \sqrt{n}\)之间的所有整数,依次检查它们能否整除\(n\),若都不能整除,则\(n\)是 ...

  9. 数据库(MySQL)最新版8.0安装教程,小白都能学会安装

    首先打开数据库官网 接下来点击不用登录注册 下载好软件,双击运行程序(中间不需要点击其他,等他运行好) 点击安装服务端 ,然后点击下一步 选择自己安装目录(一定要牢记)这里我选择默认目录,点击下一步 ...

  10. hive 将hive表数据查询出来转为json对象和json数组输出

    一.将hive表数据查询出来转为json对象输出 1.将查询出来的数据转为一行一行,并指定分割符的数据 2.使用UDF函数,将每一行数据作为string传入UDF函数中转换为json再返回 1.准备数 ...