3224: Tyvj 1728 普通平衡树
Description
您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:
1. 插入x数
2. 删除x数(若有多个相同的数,因只删除一个)
3. 查询x数的排名(若有多个相同的数,因输出最小的排名)
4. 查询排名为x的数
5. 求x的前驱(前驱定义为小于x,且最大的数)
6. 求x的后继(后继定义为大于x,且最小的数)
Input
第一行为n,表示操作的个数,下面n行每行有两个数opt和x,opt表示操作的序号(1<=opt<=6)
Output
对于操作3,4,5,6每行输出一个数,表示对应答案
Sample Input
1 106465
4 1
1 317721
1 460929
1 644985
1 84185
1 89851
6 81968
1 492737
5 493598
Sample Output
84185
492737
HINT
#include<cstdio>
#include<cstdlib>
using namespace std;
struct tree{
int l,r,sum,s,num,rnd;
}tr[];
int cnt,t1,t2,n,opt,x,root;
void updata(int k){
int l=tr[k].l,r=tr[k].r;
tr[k].s=tr[l].s+tr[r].s+tr[k].sum;
} void lturn(int &k){
int t=tr[k].r;tr[k].r=tr[t].l;tr[t].l=k;
tr[t].s=tr[k].s;updata(k);k=t;
} void rturn(int &k){
int t=tr[k].l; tr[k].l=tr[t].r;tr[t].r=k;
tr[t].s=tr[k].s;updata(k);k=t;
} void insert(int &k,int x){
if (!k){
cnt++;k=cnt;tr[k].num=x; tr[k].s=; tr[k].rnd=rand();tr[k].sum++;return;
}
tr[k].s++;
if (x<tr[k].num){
insert(tr[k].l,x);
if (tr[tr[k].l].rnd<tr[k].rnd) rturn(k);
}
else if (x>tr[k].num){
insert(tr[k].r,x);
if (tr[tr[k].r].rnd<tr[k].rnd) lturn(k);
}
else if (x==tr[k].num) {
tr[k].sum++;
return;
}
} void del(int &k,int x){
if (k==) return;
if (tr[k].num==x){
if (tr[k].sum>){
tr[k].sum--;tr[k].s--; return;
}
if (tr[k].l*tr[k].r==)k=tr[k].l+tr[k].r;
else if (tr[tr[k].l].rnd<tr[tr[k].r].rnd)
rturn(k),del(k,x);
else lturn(k),del(k,x);
}
else if (x>tr[k].num) tr[k].s--,del(tr[k].r,x);
else tr[k].s--,del(tr[k].l,x);
} int find1(int &k,int x){
if (k==) return ;
if (tr[k].num==x) return tr[tr[k].l].s+;
if (tr[k].num>x) return find1(tr[k].l,x);
if (tr[k].num<x) return tr[tr[k].l].s+tr[k].sum+find1(tr[k].r,x);
} int find2(int &k,int x){
if (k==) return ;
int l=tr[k].l,r=tr[k].r;
if (tr[l].s+<=x&&tr[l].s+tr[k].sum>=x) return tr[k].num;
if (tr[l].s>=x) return find2(l,x);
if (tr[l].s+tr[k].sum<x) return find2(r,x-tr[l].s-tr[k].sum);
} void pre(int &k,int x){
if (k==) return;
if (tr[k].num<x){
t1=k;
pre(tr[k].r,x);
}
else pre(tr[k].l,x);
} void after(int &k,int x){
if (k==) return;
if (tr[k].num>x){
t2=k;
after(tr[k].l,x);
}
else after(tr[k].r,x);
} int main(){
scanf("%d",&n);
while (n--){
scanf("%d%d",&opt,&x);
t1=t2=;
switch(opt){
case :insert(root,x); break;
case :del(root,x); break;
case :printf("%d\n",find1(root,x)); break;//查询x数的排名
case :printf("%d\n",find2(root,x));break;
case :pre(root,x);printf("%d\n",tr[t1].num);break;
case :after(root,x);printf("%d\n",tr[t2].num);break;
} }
}
3224: Tyvj 1728 普通平衡树的更多相关文章
- BZOJ 3224: Tyvj 1728 普通平衡树
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 9629 Solved: 4091[Submit][Sta ...
- BZOJ 3224 TYVJ 1728 普通平衡树 [Treap树模板]
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 7390 Solved: 3122 [Submit][S ...
- BZOJ 3224: Tyvj 1728 普通平衡树 treap
3224: Tyvj 1728 普通平衡树 Description 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除 ...
- BZOJ 3224: Tyvj 1728 普通平衡树 vector
3224: Tyvj 1728 普通平衡树 Description 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除 ...
- BZOJ 3224: Tyvj 1728 普通平衡树(BST)
treap,算是模板题了...我中间还一次交错题... -------------------------------------------------------------------- #in ...
- 【bzoj】3224: Tyvj 1728 普通平衡树
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 10097 Solved: 4302[Submit][St ...
- BZOJ 3224: Tyvj 1728 普通平衡树 or 洛谷 P3369 【模板】普通平衡树-Splay树模板题
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 22483 Solved: 10130[Submit][S ...
- 3224: Tyvj 1728 普通平衡树(finger tree)
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 19122 Solved: 8359[Submit][St ...
- 3224: Tyvj 1728 普通平衡树(新板子)
3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 17048 Solved: 7429[Submit][St ...
- 【BZOJ】3224: Tyvj 1728 普通平衡树(某不科学的oj)
http://www.lydsy.com/JudgeOnline/problem.php?id=3224 无力吐槽,无力吐槽,无力吐槽....... bzoj竟然不能用time(0)我竟然不造!!re ...
随机推荐
- c++中静态成员变量 静态成员函数 全局变量与静态函数的关系 字符串中括号的匹配编程 (笔试经历)
笔试经历 1 类中的静态变量不能通过构造函数参数列表来初始化,因为静态变量不属于哪个对象.同时静态变量在不初始化的情况下系统会自动为变量赋值,数值型赋值为零,字符型赋值为空. 非静态变量只有在定义时才 ...
- CSS3——选项卡切换
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 一款仿36氪iOS版APP源码
Features 离线缓存 解决视频播放器的网速慢卡顿 视频播放器调用简单 cell自适应高度 cell中嵌套webView cell中嵌套webView 条件实时搜索 Known problems ...
- Tomcat启动报错 Failed to start component [StandardServer[8005]]解决
SEVERE: The required Server component failed to start so Tomcat is unable to start. org.apache.catal ...
- activity和fragment的声明周期
Activity生命周期: Fragment生命周期:
- orcale授权
grant connect,resource,dba to 表名;--用户授权 CONNECT角色: --是授予最终用户的典型权利,最基本的 CREATE SESSION --建立会话 RESOURC ...
- Session对象的集合
Session StaticObjects 集合 StaticObjects 集合包含 Session 对象范围中用 <OBJECT> 标记创建的所有对象.该集合可用于确定对象特定属性的值 ...
- 用 CSS 隐藏页面元素的 5 种方法
原文链接:用 CSS 隐藏页面元素的 5 种方法,转载请注明来源! 用 CSS 隐藏页面元素有许多种方法.你可以将 opacity 设为 0.将 visibility 设为 hidden.将 disp ...
- NodeJS连接MongoDB数据库时报错
今天第一次尝试连接MongoDB数据库,具体步骤也很简单. 首先,通过NodeJS运行环境安装MongoDB包,进入要安装的目录,执行语句 npm install mongodb 安装成功后,通过如下 ...
- Windows下lex 与 yacc的使用(2)
Windows下lex 与 yacc的使用 ...