博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【BZOJ】3224: Tyvj 1728 普通平衡树
阅读量:6944 次
发布时间:2019-06-27

本文共 1332 字,大约阅读时间需要 4 分钟。

【题意】

1. 插入x数

2. 删除x数(若有多个相同的数,因只删除一个)

3. 查询x数的排名(若有多个相同的数,因输出最小的排名)

4. 查询排名为x的数

5. 求x的前驱(前驱定义为小于x,且最大的数)

6. 求x的后继(后继定义为大于x,且最小的数)

【算法】

重要的细节以注释的形式标注在代码中。

#include
#include
#include
using namespace std;const int maxn=100010;struct tree{
int l,r,sz,rnd,num;}t[maxn*2];int n,sz,root;void up(int k){t[k].sz=1+t[t[k].l].sz+t[t[k].r].sz;}void lturn(int &k){ int o=t[k].r; t[k].r=t[o].l; t[o].l=k; up(k);up(o); k=o;}void rturn(int &k){ int o=t[k].l; t[k].l=t[o].r; t[o].r=k; up(k);up(o); k=o;}void ins(int &k,int x){ if(!k){k=++sz;t[k].rnd=rand();t[k].num=x;t[k].sz=1;return;}//return t[k].sz++; if(x<=t[k].num){ ins(t[k].l,x); if(t[t[k].l].rnd
x)return min(t[k].num,suc(t[k].l,x)); else return suc(t[k].r,x);}int main(){ srand(233);//srand!!!!!!!!!! scanf("%d",&n);sz=root=0; for(int i=1;i<=n;i++){ int opt,x; scanf("%d%d",&opt,&x); if(opt==1)ins(root,x); if(opt==2)del(root,x); if(opt==3)printf("%d\n",find(root,x)+1);//+1 if(opt==4)printf("%d\n",rank(root,x)); if(opt==5)printf("%d\n",pre(root,x)); if(opt==6)printf("%d\n",suc(root,x)); } return 0;}
View Code

 

转载于:https://www.cnblogs.com/onioncyc/p/7890314.html

你可能感兴趣的文章
了解url
查看>>
时间记录日志
查看>>
Node.js
查看>>
进程 线程通信方式(转载)
查看>>
在ios上,fixed定位因为input导致手机下面出现空白,视图变小
查看>>
hdu 1695(欧拉函数 容斥定理)
查看>>
mysql在表的某一位置增加一列、删除一列、修改列名
查看>>
计算机基础知识
查看>>
SpringMVC系列(九)自定义视图、重定向、转发
查看>>
PAT 1029 Median
查看>>
需要总结的知道
查看>>
python 从小白开始 - 字符串操作(不可修改)
查看>>
管理现有数据库-web系统
查看>>
无缝滚动
查看>>
JVM(四)垃圾收集器_分代收集器
查看>>
根据图片路径生成二进制流,下载图片
查看>>
正则表达式的基本用法
查看>>
Shell 同步时间脚本
查看>>
条目十五《注意strng实现的多样性》
查看>>
P1387 最大正方形
查看>>