当前位置: 首页 > news >正文

宣威市住房与城乡建设局网站怎样开通微信公众号

宣威市住房与城乡建设局网站,怎样开通微信公众号,成都旅游公司哪家好,微小店网站建设平台平衡树——Treap 文章目录 平衡树——TreapBST定义性质操作插入insert(o, v)删除del(o, v)找前驱 / 后继get_prev(o)、get_next(o)查找最大 / 最小值get_min(o)、get_max(o)求元素排名get_rank(o)查找排名为 k k k的元素get_value_by_rank 平衡树左旋、右旋zag(o)、zig(o)左旋右…

平衡树——Treap

文章目录

  • 平衡树——Treap
    • BST
    • 平衡树
      • 左旋、右旋`zag(o)、zig(o)`
        • 左旋
        • 右旋

BST

定义

  1. 空树是二叉搜索树。

  2. 若二叉搜索树的左子树不为空,则其左子树上所有点的附加权值均小于其根节点的值。

  3. 若二叉搜索树的右子树不为空,则其右子树上所有点的附加权值均大于其根节点的值。

  4. 二叉搜索树的左右子树均为二叉搜索树。

性质

二叉搜索树的中序遍历是一个有序序列

操作

插入insert(o, v)

  1. o o o 为空,直接返回一个值为 v v v 的新节点。

  2. o o o 的权值等于 v v v,该节点的附加域该值出现的次数自增 1 1 1

  3. o o o 的权值大于 v v v,在 o o o 的左子树中插入权值为 v v v 的节点。

  4. o o o 的权值小于 v v v,在 o o o 的右子树中插入权值为 v v v 的节点。

删除del(o, v)

先在二叉搜索树中找到权值为 v 的节点,分类讨论如下:

  1. 若该节点的附加 cnt \textit{cnt} cnt 大于 1 1 1,只需要减少 cnt \textit{cnt} cnt

  2. 若该节点的附加 cnt \textit{cnt} cnt 1 1 1

    • o o o 为叶子节点,直接删除该节点即可。

    • o o o 为链节点,即只有一个儿子的节点,返回这个儿子。

    • o o o 有两个非空子节点,一般是用它左子树的最大值或右子树的最小值代替它,然后将它删除。

找前驱 / 后继get_prev(o)、get_next(o)

前(后)驱表示中序遍历中前(后)一个位置,以前驱为例

  1. 存在左子树,则找到左子树中最右边的元素,并返回。
  2. 不存在左子树,找第一个祖先节点中节点 o o o位于其右子树中,返回这个祖先节点

查找最大 / 最小值get_min(o)、get_max(o)

由二叉搜索树的性质可得,二叉搜索树上的最小值为二叉搜索树左链的顶点,最大值为二叉搜索树右链的顶点。

求元素排名get_rank(o)

排名定义为将数组元素排序后第一个相同元素之前的数的个数加一

查找一个元素的排名,首先从根节点跳到这个元素,若向右跳,答案加上左儿子节点个数加当前节点重复的数个数,最后答案加上终点的左儿子子树大小加一。

查找排名为 k k k的元素get_value_by_rank

在一棵子树中,根节点的排名取决于其左子树的大小。

若其左子树的大小大于等于 k k k,则该元素在左子树中;

若其左子树的大小在区间 [ k − cnt , k − 1 ] [k-\textit{cnt},k-1] [kcnt,k1] cnt \textit{cnt} cnt 为当前结点的值的出现次数)中,则该元素为子树的根节点;

若其左子树的大小小于 k − cnt k-\textit{cnt} kcnt,则该元素在右子树中。

平衡树

对于一般的二叉搜索树,有可能退化为链表。想象一棵每个结点只有右孩子的二叉搜索树,那么它的性质就和链表一样,插入与查找时间都是 O ( n ) O(n) O(n)
二叉搜索树的「平衡」概念是指:每一个结点的左子树和右子树高度差最多为 1。

可以对不满足平衡条件的二叉搜索树进行调整,使不平衡的二叉搜索树变得平衡。

调整要保证的标准还有二叉搜索树先天自带的条件:二叉搜索树,按照中序遍历,得到从小到大的结点值序列。对于任意一个结点,左子树各结点的最大值,小于该结点的值;该结点的值,小于右子树各结点的最小值。只有保证这一点才能称为一个二叉搜索树。

左旋、右旋zag(o)、zig(o)

左旋

左旋,左旋也称为「左单旋转」或「RR 平衡旋转」。对于结点 A A A 的左旋操作是指:将 A A A 的右孩子 B B B 向左上旋转,代替 A A A 成为根节点,将 A A A 结点向左下旋转成为 B B B 的左子树的根结点, B B B 的原来的左子树变为 A A A 的右子树。

右旋

右旋,右旋也称为「右单旋转」或「LL 平衡旋转」。对于结点 A A A 的右旋操作是指:将 A A A 的左孩子 B B B 向右上旋转,代替 A A A 成为根节点,将 A A A 结点向右下旋转成为 B B B 的右子树的根结点, B B B 的原来的右子树变为 A A A 的左子树。

在这里插入图片描述

http://www.yayakq.cn/news/149005/

相关文章:

  • 如何做网站模特网站发布系统
  • 马鞍山做网站公司电子商务网站推广的主要方法
  • 六安哪里有做推广网站个体户忘了年报是否罚款
  • 网站前台功能介绍宁波高端建站
  • 照片做3d网站免费建设淘客网站
  • 小学生做电子小报的网站青岛网站建设开发外包
  • 阿里巴巴网站建设过程如何看到网站的建设时间
  • 成功的网站建设智慧团建官网入口登录
  • 乐清新闻综合频道上海网站优化上
  • 免费网站建设资讯南京网站的优化
  • 做网站一定要有空间吗公路建设项目可行性研究报告编制办法哪个网站查最新版
  • 建立平台网站要多久制作单页网站教程
  • 古典网站源码网站设计培训哪里好
  • 河北路泰建设工程有限公司网站江苏网站建设基本流程
  • h5 网站建设wordpress在线升级
  • 哪个网站可以代做软件网站建设找博网
  • 网站开发 原理有些网站下方只有版权没有ICP
  • 医生工作室网站建设那个网站的详情做的好
  • 免费建立自己的网站合肥网站设
  • 全面的聊城网站建设甘肃建网站
  • 网站建设有哪些规章制度如何推动一个教学网站的建设
  • 哈尔滨最好的网站建设公司在哪个网站找婚照公司
  • 济南建站公司注意事项补习班
  • 什么网站找厂做袜子wordpress seo主题
  • 大型房产网站模板电商平台都有哪些平台
  • 网站建设公司的运营方式海口网站建设解决方案
  • 深圳哪家网站建设好秦皇岛十大必去景点
  • 企业网站流程图莒南县建设局网站
  • 天津建设网站分包服务卡深圳品牌网站制作平台
  • 1688网站建设与维护单页网页设计图片