《征服数据结构》树堆(Treap)

摘要:

1,Treap的介绍

2,Treap节点的插入

3,Treap节点的删除

4,Treap和笛卡尔树的区别

1,Treap的介绍

Treap又叫树堆,属于一种自平衡二叉搜索树,是由单词Tree和Heap构成,是一种具有二叉搜索树和堆两种数据结构的特性。在前面我们讲过《笛卡尔树》,它也是一种具有二叉搜索树和堆的两种数据结构的特性,关于它俩的区别我们后面在介绍。

我们知道如果随机使用一组数据创建二叉搜索树,则二叉搜索树很可能会退化成一个链表,增加了操作的时间复杂度。这个时候我们可以给每个节点随机生成一个优先级,这个优先级要满足堆的特性。因为是随机生成的,所以从概率上来说退化成链表的可能性就非常小。

Treap在节点插入和删除的时候也会进行旋转,因为它不是高度平衡的,所以Treap比我们前面讲的《AVL树》要简单很多,在讲解之前我们先来看下Treap的节点类。

Java 代码:

go 复制代码
class TreapNode {
    int key, priority;
    TreapNode left, right;

    public TreapNode(int key) {
        this.key = key;
        // 节点优先级,满足堆的特性,随机生成的
        this.priority = new Random().nextInt();
        this.left = this.right = null;
    }
}

C++ 代码:

go 复制代码
struct TreapNode {
    int key, priority;
    TreapNode *left = nullptr;
    TreapNode *right = nullptr;

    // 节点优先级priority,满足堆的特性,随机生成的
    TreapNode(int key) : key(key), priority(rand()) {}
};

节点类中有一个优先级priority,它是随机生成的,要满足堆的特性,这里我们使用最大堆,堆顶元素是优先级最高的。

再来看下节点的旋转,旋转不会改变二叉搜索树的特性,但会改变堆的特性,旋转的目的就是把优先级高的节点往上调整,优先级低的节点往下调整,这和我们前面讲的《数据结构堆》类似,不过在堆中是直接交换,不是通过旋转。

相关推荐
神里流~霜灭29 分钟前
蓝桥备赛指南(12)· 省赛(构造or枚举)
c语言·数据结构·c++·算法·枚举·蓝桥·构造
双叶8361 小时前
(C语言)单链表(1.0)(单链表教程)(数据结构,指针)
c语言·开发语言·数据结构·算法·游戏
学习编程的gas2 小时前
数据结构——队列的实现
数据结构
wuqingshun3141592 小时前
蓝桥杯 切割
数据结构·c++·算法·职场和发展·蓝桥杯
JohnFF3 小时前
48. 旋转图像
数据结构·算法·leetcode
代码AC不AC3 小时前
【数据结构】队列
c语言·数据结构·学习·队列·深度讲解
小林熬夜学编程3 小时前
【高并发内存池】第八弹---脱离new的定长内存池与多线程malloc测试
c语言·开发语言·数据结构·c++·算法·哈希算法
ゞ 正在缓冲99%…3 小时前
leetcode152.乘积最大子数组
数据结构·算法·leetcode
闯闯爱编程4 小时前
数组与特殊压缩矩阵
数据结构·算法·矩阵
laimaxgg5 小时前
数据结构B树的实现
开发语言·数据结构·c++·b树·算法