题目

你需要写一种数据结构支援以下操作。

  1. 插入元素。
  2. 删除元素。
  3. 查询元素的排名。
  4. 查询第k小的元素。
  5. 查询元素前趋。
  6. 查询元素后继。

题解

BBST裸题。

代码

#include <cstdio>
#include <iostream>
#define ll long long
using namespace std;
#ifdef D
const int maxn = 100;
#else
const int maxn = 100005;
#endif
int ch[maxn][2], fa[maxn], size[maxn], data[maxn], cnt[maxn];
int rt, n, m;
ll sz = 0;
int read() {
int x = 0, f = 1;
char ch = getchar();
while (ch < '0' || ch > '9') {
if (ch == '-')
f = -1;
ch = getchar();
}
while (ch >= '0' && ch <= '9') {
x = x * 10 + ch - '0';
ch = getchar();
}
return x * f;
}
inline void update(int x) {
size[x] = size[ch[x][0]] + size[ch[x][1]] + cnt[x];
}
inline void zig(int x) {
int y = fa[x], z = fa[y], l = (ch[y][1] == x), r = l ^ 1;
fa[ch[y][l] = ch[x][r]] = y;
fa[ch[x][r] = y] = x;
fa[x] = z;
if (z)
ch[z][ch[z][1] == y] = x;
update(y);
}
inline void splay(int x, int aim = 0) { //调整x成为aim的儿子
for (int y; (y = fa[x]) != aim; zig(x)) {
if (fa[y] != aim)
zig((ch[y][0] == x) == (ch[fa[y]][0] == y) ? y : x);
}
if (aim == 0)
rt = x;
update(x);
}
inline void insert(int v) {
int x = rt;
if (rt == 0) {
rt = x = ++sz;
data[x] = v;
fa[x] = ch[x][0] = ch[x][1] = 0;
size[x] = cnt[x] = 1;
return;
}
while (x) {
size[x]++;
if (v == data[x]) {
cnt[x]++;
return;
}
int &y = ch[x][v >= data[x]];
if (y == 0) {
y = ++sz;
data[y] = v;
fa[y] = x;
ch[y][0] = ch[y][1] = 0;
size[y] = cnt[y] = 1;
x = y;
break;
}
x = y;
}
splay(x);
}
int rank(int v) {
int ret = 0, ans, x = rt;
while (x) {
if (v > data[x]) {
ret += size[ch[x][0]] + cnt[x];
x = ch[x][1];
} else {
if (v == data[x]) {
return ret + size[ch[x][0]] + 1;
}
x = ch[x][0];
}
}
}
int kth(int v) {
int x = rt;
while (x) {
if (v >= size[ch[x][0]] + 1 && v <= size[ch[x][0]] + cnt[x])
return data[x];
if (v > size[ch[x][0]] + cnt[x]) {
v -= size[ch[x][0]] + cnt[x];
x = ch[x][1];
} else
x = ch[x][0];
}
}
int pre(int v) {
int ans;
for (int y = rt; y;)
if (data[y] < v)
ans = data[y], y = ch[y][1];
else
y = ch[y][0];
return ans;
}
int succ(int v) {
int ans;
for (int y = rt; y;)
if (data[y] <= v)
y = ch[y][1];
else
ans = data[y], y = ch[y][0];
return ans;
}
inline void del(int v) {
int x = rt;
while (x) {
size[x]--;
if (data[x] == v) {
cnt[x]--;
break;
}
int &y = ch[x][v >= data[x]];
x = y;
}
if (cnt[x] != 0)
return;
splay(x);
if (ch[x][0] == 0) {
rt = ch[x][1];
fa[rt] = 0;
return;
}
if (ch[x][1] == 0) {
rt = ch[x][0];
fa[rt] = 0;
return;
}
x = ch[rt][0];
while (ch[x][1])
x = ch[x][1];
splay(x, rt);
ch[x][1] = ch[rt][1];
fa[ch[x][1]] = x;
size[x] = size[rt] - 1;
fa[x] = 0;
rt = x;
}
int main() {
#ifdef DEBUG
freopen("input", "r", stdin);
#endif
scanf("%d", &n);
rt = sz = 0;
while (n--) {
int opt = read();
if (opt == 1) {
int x = read();
insert(x); // O(log n)
} else if (opt == 2) {
int x = read();
del(x); // O(log n)
} else if (opt == 3) {
int k = read();
printf("%d\n", rank(k));
} else if (opt == 4) {
int k = read();
printf("%d\n", kth(k));
} else if (opt == 5) {
int x = read();
printf("%d\n", pre(x));
} else if (opt == 6) {
int x = read();
printf("%d\n", succ(x));
}
}
}

[bzoj3224]Tyvj 1728 普通平衡树——splay模板的更多相关文章

  1. bzoj3224: Tyvj 1728 普通平衡树(splay)

    3224: Tyvj 1728 普通平衡树 题目:传送门 题解: 啦啦啦啦又来敲个模版水经验啦~ 代码: #include<cstdio> #include<cstring> ...

  2. [BZOJ3224]Tyvj 1728 普通平衡树

    [BZOJ3224]Tyvj 1728 普通平衡树 试题描述 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个) ...

  3. bzoj3224: Tyvj 1728 普通平衡树(平衡树)

    bzoj3224: Tyvj 1728 普通平衡树(平衡树) 总结 a. cout<<(x=3)<<endl;这句话输出的值是3,那么对应的,在splay操作中,当父亲不为0的 ...

  4. 【BZOJ3224】Tyvj 1728 普通平衡树 Splay

    Description 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个)3. 查询x数的排名(若有多个相同的数 ...

  5. bzoj3224 Tyvj 1728 普通平衡树(名次树+处理相同)

    3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 5354  Solved: 2196[Submit][Sta ...

  6. BZOJ3224 洛谷3369 Tyvj 1728 普通平衡树 splay

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3224 题意概括 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. ...

  7. 绝对是全网最好的Splay 入门详解——洛谷P3369&BZOJ3224: Tyvj 1728 普通平衡树 包教包会

    平衡树是什么东西想必我就不用说太多了吧. 百度百科: 一个月之前的某天晚上,yuli巨佬为我们初步讲解了Splay,当时接触到了平衡树里的旋转等各种骚操作,感觉非常厉害.而第二天我调Splay的模板竟 ...

  8. bzoj3224: Tyvj 1728 普通平衡树(打个splay暖暖手)

    (其实今天好热啊? 题目大意:插入,删除,k小,前驱后继,数的排名. splay和treap裸题...过几天补个treap的 splay: #include<iostream> #incl ...

  9. 【Splay】bzoj3224 Tyvj 1728 普通平衡树

    #include<cstdio> #include<iostream> #include<cstring> #include<algorithm> us ...

随机推荐

  1. IOException: win32 io returned 267. Path:

    unity3d在导出android项目时出现了这个错误,找了一圈也没找到原因,最后把项目名中空格去掉后OK了,坑啊!!!!

  2. adb常用命令(手机测试)

                                                   ADB安装与常用命令详解 一.ADB意义 adb的全称为Android Debug Bridge,就是起到 ...

  3. 生产者与消费者-N:1-基于list

    多个生产者/一个消费者: /** * 生产者 */ public class P { private MyStack stack; public P(MyStack stack) { this.sta ...

  4. CSS : @media 示例

    .example { padding: 20px; color: white; } /* Extra small devices (phones, 600px and down) */ @media ...

  5. m个苹果放在n个盘子中有多少种结果

    题目 m个苹果放在n个盘子中有多少种结果,前置条件: 允许存在空盘 重复的摆放结果忽略不计 根据题意,也就是有3种情况,的确完全重复的摆放方式是没多大意义的 思路 这题可以用枚举的描述方式进行尾递归求 ...

  6. CentOS7 Zabbix4.0环境下的安装和配置实例

    1.安装准备 Zabbix4.0对基础架构有一定的要求,对的英文尤其PHP状语从句:MySQL: 类型 内容 服务端运行环境 Linux和PHP与Web服务器和数据库 服务端操作系统 CentOS7. ...

  7. AndroidStudio0.5.5发布

    Google%E5%9C%A8%E5%BC%80%E6%BA%90%E4%B8%8A%E7%9A%84%E8%B4%A1%E7%8C%AE http://music.baidu.com/songlis ...

  8. 超像素 superpixels 是什么东西

    毕业设计要做图像分割 识别什么的. 看论文看到 superpixels 开始脑补是  像素插值算出来的 后来越看越不想,搜索发现根本是另外一回事 http://blog.sina.com.cn/s/b ...

  9. Jquery tmpl详解

    Jquery tmpl是动态请求数据来更新页面非常常用的方法,比如博客评论的分页动态加载,微博的滚动加载和定时请求加载等. 这些情况下,动态请求返回的数据一般不是已拼好的 HTML 就是 JSON 或 ...

  10. python字符串排序方法

    一般情况下,python中对一个字符串排序相当麻烦: 一.python中的字符串类型是不允许直接改变元素的.必须先把要排序的字符串放在容器里,如list. 二.python中的list容器的sort( ...