随笔- 106  文章- 0  评论- 0  阅读- 27877 

Treap树    =     tree+heap

数和堆的集合,每个节点有值val,也有优先级key,那么这棵树的形态就被确定了,和插入顺序无关了(有赖于优先级

避免退化成链:再生成节点时,随机生成优先级,然后插入时动态调整

 有旋treap:依靠旋转来维持heap的平衡

1、FHQ treap又称无旋treap,没有旋转操作,使用分裂和合并两个操作维护树的平衡

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
struct node{
    int l,r;
    int val;
    int key;
    int size;
}tr[N];
int root,idx;
int newnode(int v){
}
void pushup(){  //向上更新
}
void split(int p,int v,int &x,int &y){ //分裂操作 注意在递归的过程中,连接了分裂后的新边
}
int merg(int x,int y){  //合并,根据key的大小,注意在递归的过程中,连接了分裂后的新边
}
void inser(int v){ //插入节点,先分裂,再合并,连续两次合并
}
void del(int v){ //删除操作,先分裂、再合并
}
int get_k(int p,int k){ //返回第k个节点
}
void get_pre(int v){ //找前驱
}
void get_suc(int v){ //找后继
}
void get_rank(int v){//排名
}
void get_val(int k){//数值
}

  

P3369 【模板】普通平衡树

 

  

文艺平衡树

还是有旋转操作的

  

删除:如果有两个子节点,找到优先级大的,把x向反方向旋转,也就是把x向树的下层调整,直到旋转到叶子节点

!很多题目涉及名次树

常用操作:

struct node,旋转rotate,插入insert(),查找第k大的数kth(),查询某个数find()【名次树】

少林 hdu 4585

  

 posted on   shirlybabyyy  阅读(17)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话
历史上的今天:
2020-06-03 公平组合游戏
2020-06-03 概论和数学期望
2020-06-03 组合数学
点击右上角即可分享
微信分享提示