treap数组版
然而就是将指针的地方换成int引用
就是存个代码
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<ctime>
using namespace std;
struct node
{
int val;
int yuk;
int siz;
int key;
int ch[2];
};
node t[501000];
int tail;
int cmp(int now,int val)
{
if(t[now].val==val) return -1;
return t[now].val > val ? 0 : 1 ;
}
void sum(int &now)
{
t[now].siz=t[t[now].ch[0]].siz+t[t[now].ch[1]].siz+t[now].yuk;
return ;
}
void rotato(int &now,int base)
{
int k=t[now].ch[base^1];
t[now].ch[base^1]=t[k].ch[base];
t[k].ch[base]=now;
sum(now); sum(k);
now=k;
}
int New(int val)
{
++tail;
t[tail].ch[0]=t[tail].ch[1]=0;
t[tail].siz=1;t[tail].yuk=1;
t[tail].val=val;
t[tail].key=rand();
return tail;
}
void init()
{
t[0].val=0;t[0].yuk=0;
t[0].key=-1;
t[0].ch[0]=t[0].ch[1]=0;
srand(time(NULL));
return ;
}
void insert(int &now,int val)
{
if(now==0){now=New(val);return ;}
int dir=cmp(now,val);
if(dir==-1){t[now].yuk+=1;t[now].siz+=1;return ;}
insert(t[now].ch[dir],val);
if(t[t[now].ch[dir]].key>t[now].key) rotato(now,dir^1);
sum(now);
}
void del(int &now,int val)
{
int dir=cmp(now,val);
if(dir==-1)
if(t[now].yuk>1){t[now].siz-=1,t[now].yuk-=1;return;}
else
{
if(t[now].ch[1]&&t[now].ch[0])
{
int nxt= t[t[now].ch[0]].key > t[t[now].ch[1]].key ? 0 : 1;
rotato(now,nxt^1);
del(t[now].ch[nxt^1],val);
sum(now);return ;
}
if(t[now].ch[1]){now=t[now].ch[1];sum(now);return ;}
else {now=t[now].ch[0];sum(now);return ;}
}
del(t[now].ch[dir],val);sum(now);
return;
}
int nxt(int now,int val)
{
if(!now) return 0x7fffffff;
if(t[now].val>val)
return min(t[now].val,nxt(t[now].ch[0],val));
else
return nxt(t[now].ch[1],val);
}
int pre(int now,int val)
{
if(!now) return -0x7fffffff;
if(t[now].val<val)
return max(t[now].val,pre(t[now].ch[1],val));
else
return pre(t[now].ch[0],val);
}
int find(int &now,int val)
{
int dir=cmp(now,val);
if(dir==-1) return t[t[now].ch[0]].siz+1;
return find(t[now].ch[dir],val) + ( dir ? t[t[now].ch[0]].siz + t[now].yuk : 0);
}
int kth(int &now,int k)
{
if(t[t[now].ch[0]].siz<k&&t[t[now].ch[0]].siz+t[now].yuk>=k)
return t[now].val;
if(k<=t[t[now].ch[0]].siz)
return kth(t[now].ch[0],k);
else
return kth(t[now].ch[1],k-t[t[now].ch[0]].siz-t[now].yuk);
}
int root;
void visit(int now)
{
if(!now)
return ;
visit(t[now].ch[0]);
printf("%d ",t[now].val);
visit(t[now].ch[1]);
return ;
}
int main()
{
int n;
scanf("%d",&n);
int a,b;
for(int i=1;i<=n;i++)
{
scanf("%d%d",&a,&b);
switch(a)
{
case 1:insert(root,b);break;
case 2:del(root,b);break;
case 3:printf("%d\n",find(root,b));break;
case 4:printf("%d\n",kth(root,b));break;
case 5:insert(root,b);printf("%d\n",pre(root,b));del(root,b);break;
case 6:insert(root,b);printf("%d\n",nxt(root,b));del(root,b);break;
}
//visit(root);printf("\n");
}
}
treap数组版的更多相关文章
- HDU 4287 Intelligent IME(字典树数组版)
Intelligent IME Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- treap完全版模板
这是我综合poj1442 3481 2352的treap操作 得到treap完全版模板.(经测AC) 结构体Tree { int key; //键值 int size; //该子树总节点个数 int ...
- hdu 1277 AC自动机入门(指针版和数组版)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1277 推荐一篇博客(看思路就可以,实现用的是java): https://www.cnblogs.co ...
- Codeforces Gym101502 I.Move Between Numbers-最短路(Dijkstra优先队列版和数组版)
I. Move Between Numbers time limit per test 2.0 s memory limit per test 256 MB input standard inpu ...
- 字典树模板( 指针版 && 数组版 )
模板 : #include<string.h> #include<stdio.h> #include<malloc.h> #include<iostream ...
- 非旋 treap 结构体数组版(无指针)详解,有图有真相
非旋 $treap$ (FHQ treap)的简单入门 前置技能 建议在掌握普通 treap 以及 左偏堆(也就是可并堆)食用本blog 原理 以随机数维护平衡,使树高期望为logn级别, FHQ ...
- 非旋treap (fhq treap) 指针版
传送门 看了一圈,好像真的没什么用指针的呢.. 明明觉得指针很好看(什么??你说RE???听不见听不见) 其实我觉得用数组的话不RE直接WA调起来不是更困难嘛,毕竟通过gdb还可以知道哪里RE,WA就 ...
- 《Java从入门到放弃》JavaSE篇:综合练习——单身狗租赁系统(数组版)
因为现在只学习了基本语法,所以在综合练习之前,先补充关于方法概念. 方法的作用:把一系列的代码放在一起,然后再取个别名.之后通过这个别名的调用,就相当于执行了这一系列的代码. 方法的语法:([]中的内 ...
- Java课程课后作业190315之最大连续子数组(二维数组版)
,, 在本周的课堂上,老师再一次提高了要求,将一维数组升级成为了二维数组,然后求出块状的连续子数组. 一开始还想着借鉴之前球一维数组的O(n)的算法,后来还是没有找到头绪,舍友讲了自己的办法,但是没有 ...
随机推荐
- Windows下VsCode的简单配置
1. 安装插件 2. 配置终端软件 安装cmder 添加cmder 按下ctrl+shift+p键,输入setting,打开user settings如图: 将 "terminal.int ...
- wait、notify和notifyAll
生产者消费者模型是我们学习多线程知识的一个经典案例,一个典型的生产者消费者模型如下: public void produce() { synchronized (this) { while (mBuf ...
- team foundation server 工具的使用
1.打开TFS工具点击创建集合,填写集合名称,下一步,按照步骤一步一步的往下操作. 2.创建完集合以后,打开VS工具,如下图,在主页上左键选择新建团队项目. 3.选择团队项目,然后选择新建的项目集合和 ...
- WebStorm 预览时把浏览器地址localhost 改成IP
最近在使用WebStorm时,预览网页时地址总是显示的 http://localhost:63342/... ,如果要调试其它设备感觉很不方法,此时肯定首先想到的亲爱的度娘,但是貌似没有真正很解决问题 ...
- Linux cp命令拷贝 不覆盖原有的文件
cp 参数说明: -i或--interactive 覆盖既有文件之前先询问用户. -r 递归处理,将指定目录下的文件与子目录一并处理. -R或--recursive 递归处理,将指定目录下的所有 ...
- Oracle PL/SQL 实现excel PMT函数、PPMT函数
PMT函数 1.每月本息金额 = (本金×月利率×(1+月利率)^还款月数)÷ ((1+月利率)^还款月数-1) ,in_financeAmount in number) return number ...
- Numpy的那些事儿
2 NumPy-快速处理数据 标准安装的Python中用列表(list)保存一组值,可以用来当作数组使用,不过由于列表的元素可以是任何对象,因此列表中所保存的是对象的指针.这样为了保存一个简单的[1, ...
- 牛客网Java刷题知识点之输入流、输出流、字节流、字符流、字节流的抽象基类(InputStream、OutputStream)、字符流的抽象基类(Reader、Writer)、FileWriter、FileReader
不多说,直接上干货! IO流用来处理设备之间的数据传输. java对数据的操作是通过流的方式. java用于操作流的对象都在IO包中. IO流按操作数据分为两种:字节流和字符流. IO流按流向分为:输 ...
- ThinkPHP 统计数据(数字字段)更新 setInc 与 setDec 方法
ThinkPHP 统计数据更新 ThinkPHP 内置了对统计数据(数字字段)的更新方法: setInc():将数字字段值增加 setDec():将数字字段值减少 setInc() ThinkPHP ...
- This blog Test the Open Live Writer
1. We print HELLOWORLD when we first learned to code, I want to Write this blog to test the software ...