题目链接:

https://www.lydsy.com/JudgeOnline/problem.php?id=3224

思路:

splay树模板题:

推荐博客:https://blog.csdn.net/clove_unique/article/details/50630280

b站上splay树的讲解视频也可以看下,讲的很好,推荐看完视频了解了splay的原理再写

实现代码:

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int M = 1e5+;
const int inf = <<;
struct node{
int fa,s[],x,size,cnt;
}tr[M];
int top,root,n;
void pushup(int k){
tr[k].size = tr[tr[k].s[]].size+tr[tr[k].s[]].size+tr[k].cnt;
} void rotate(int k){
int x = tr[k].fa,y = tr[x].fa,b=tr[x].s[]==k;
tr[y].s[tr[y].s[]==x]=k;tr[k].fa=y;
tr[x].s[b]=tr[k].s[b^]; tr[tr[k].s[b^]].fa=x;
tr[k].s[b^]=x; tr[x].fa = k;
pushup(x); pushup(k);
} void splay(int x,int go){ //伸展操作
int y = tr[x].fa,z = tr[y].fa;
for(;tr[x].fa^go;rotate(x)){
y = tr[x].fa,z = tr[y].fa;
if(z^go) (tr[y].s[] == x)^(tr[z].s[]==y)?rotate(x):rotate(y);
}
if(!go) root = x;
} void insert(int x){ //插入操作
int u = root,fa = ;
for(;u&&tr[u].x^x;u=tr[u].s[x>tr[u].x]) fa = u;
if(u) tr[u].cnt++; //若已经有这个数了,到cnt++即可
else{ //新建一个节点
u = ++top;
if(fa) tr[fa].s[x>tr[fa].x] = u;
tr[top].fa = fa;tr[top].x = x;tr[top].cnt = tr[top].size = ;
}
splay(u,); //splay 到根
}
//这个函数还有一个功能是把一个跟x不相隔仍荷属的数转移到根
int rank(int x){ //查找x的排名
int u = root;
if(!u) return ;
for(;tr[u].s[x>tr[u].x]&&x^tr[u].x;u=tr[u].s[x>tr[u].x]);
splay(u,); //splay 到根
return tr[tr[u].s[]].size;
}
//求x的前驱后继
int next(int x,int f){ //f=0表示前驱,f=1表示后继,返回的是编号
rank(x); //将与x不相隔任何数的数转移到根
int u = root;
if(tr[u].x>x&&f||tr[u].x<x&&!f) return u; //若已经是答案,则返回
u = tr[u].s[f];
while(tr[u].s[f^]) u = tr[u].s[f^]; //查找前驱时在左子树中查找最大值,后继反之
return u;
} void erase(int x){
int up = next(x,),lo = next(x,),u; //得到前驱后继
splay(lo,); splay(up,lo); //移成一个好局面
u = tr[up].s[];
if(tr[u].cnt > ){
tr[u].cnt--;
splay(u,);
}
else {
tr[up].s[] = ;
pushup(up); pushup(lo);
}
} int find(int x){
x++;
int u = root,son;
if(tr[u].size < x) return ; //没有这个数
while(){
son = tr[u].s[];
if(tr[son].size >= x) u = son;
else if(x>tr[son].size+tr[u].cnt)
x -= tr[son].size + tr[u].cnt, u = tr[u].s[];
else break;
}
splay(u,);
return tr[u].x;
} int main(){
scanf("%d",&n);
int op,x;
insert(-inf); insert(inf);
for(int i = ;i <= n;i ++){
scanf("%d%d",&op,&x);
switch(op){
case : insert(x);break;
case : erase(x); break;
case : printf("%d\n",rank(x));break;
case : printf("%d\n",find(x)); break;
case : printf("%d\n",tr[next(x,)].x); break;
case : printf("%d\n",tr[next(x,)].x); break;
}
}
return ;
}

bzoj 3224: Tyvj 1728 普通平衡树 && loj 104 普通平衡树 (splay树)的更多相关文章

  1. BZOJ 3224: Tyvj 1728 普通平衡树

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

  2. BZOJ 3224 TYVJ 1728 普通平衡树 [Treap树模板]

    3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 7390  Solved: 3122 [Submit][S ...

  3. BZOJ 3224: Tyvj 1728 普通平衡树 treap

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

  4. BZOJ 3224: Tyvj 1728 普通平衡树 vector

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

  5. BZOJ 3224: Tyvj 1728 普通平衡树(BST)

    treap,算是模板题了...我中间还一次交错题... -------------------------------------------------------------------- #in ...

  6. BZOJ 3224: Tyvj 1728 普通平衡树 or 洛谷 P3369 【模板】普通平衡树-Splay树模板题

    3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 22483  Solved: 10130[Submit][S ...

  7. BZOJ 3224 Tyvj 1728 普通平衡树模板

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=3224 题目大意: 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以 ...

  8. bzoj 3224/Tyvj 1728 普通平衡树(splay)

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

  9. fhq_treap || BZOJ 3224: Tyvj 1728 普通平衡树 || Luogu P3369 【模板】普通平衡树

    题面:[模板]普通平衡树 代码: #include<cstdio> #include<cstring> #include<iostream> #include< ...

随机推荐

  1. 通过重建清理SVN服务器无用目录,不丢失其他目录修改记录

    1.主要时有时间希望调整一些文件的目录结构,或者移除一个大量占用空间的文件节省服务器磁盘,但是又不希望调整后,对应的修改记录丢失.这时可以通过服务器目录重建实现. 2.重建后只是被排除掉的目录的修改记 ...

  2. CF932F Escape Through Leaf 斜率优化、启发式合并

    传送门 \(DP\) 设\(f_i\)表示第\(i\)个节点的答案,\(S_i\)表示\(i\)的子节点集合,那么转移方程为\(f_i = \min\limits_{j \in S_i} \{a_i ...

  3. Zookeeper-集群与单机实践

    我用的是linux,CentOS7.3,zookeeper的版本是3.4.6,工具XShell.上传zookeeper的压缩包后我们开始操作. 集群模式: 1.解压zookeeper,路径随意 tar ...

  4. 机器学习sklearn19.0聚类算法——Kmeans算法

    一.关于聚类及相似度.距离的知识点 二.k-means算法思想与流程 三.sklearn中对于kmeans算法的参数 四.代码示例以及应用的知识点简介 (1)make_blobs:聚类数据生成器 sk ...

  5. 【强化学习】python 实现 saras lambda 例一

    本文作者:hhh5460 本文地址:https://www.cnblogs.com/hhh5460/p/10147265.html 将例一用saras lambda算法重新撸了一遍,没有参照任何其他人 ...

  6. Verilog对数据进行四舍五入(round)与饱和(saturation)截位

    转自https://www.cnblogs.com/liujinggang/p/10549095.html 一.软件平台与硬件平台 软件平台: 操作系统:Windows 8.1 64-bit 开发套件 ...

  7. JS 数据处理技巧及小算法汇总

    前言: 金秋九月的最后一天,突然发现这个月博客啥也没更新,不写点什么总觉得这个月没啥长进,逆水行舟,不进则退,前进的路上贵在坚持,说好的每个月至少一到两篇,不能半途而废!好多知识写下来也能加深一下自身 ...

  8. 普通程序员看k8s基于角色的访问控制(RBAC)

    一.知识准备 ● 上一节描述了k8s的账户管理,本文描述基于角色的访问控制 ● 网上RBAC的文章非常多,具体概念大神们也解释得很详细,本文没有站在高屋建瓴的角度去描述RBAC,而是站在一个普通程序员 ...

  9. Centos下SFTP双机高可用环境部署记录

    SFTP(SSH File Transfer Protocol),安全文件传送协议.有时也被称作 Secure File Transfer Protocol 或 SFTP.它和SCP的区别是它允许用户 ...

  10. Gitlab备份和恢复操作记录

    前面已经介绍了Gitlab环境部署记录,这里简单说下Gitlab的备份和恢复操作记录: 1)Gitlab的备份目录路径设置 [root@code-server ~]# vim /etc/gitlab/ ...