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

电商网站网址大全深圳百度推广开户

电商网站网址大全,深圳百度推广开户,公司网站seo外包,上海网站开发设计培训数据结构-平衡树 前置知识 二叉树二叉树的中序遍历 问题 维护一个数据结构,支持插入元素、删除元素、查询元素的排名、查询排名对应的元素、查询元素的前驱、查询元素的后继等。 BST(二叉搜索树) 作为一个基本无效(很容易卡掉…

数据结构-平衡树


前置知识
  • 二叉树
  • 二叉树的中序遍历

问题

维护一个数据结构,支持插入元素、删除元素、查询元素的排名、查询排名对应的元素、查询元素的前驱、查询元素的后继等。

BST(二叉搜索树)

作为一个基本无效(很容易卡掉)的数据结构,将其放在这里讲可能更为合适。。。
BST 的思想,来自于二叉树的 DFS 序。
设想一下,若一个二叉树的中序遍历正好递增,也就是说,始终有 左儿子 ≤ 根 ≤ 右儿子 左儿子\le根\le右儿子 左儿子右儿子,那么不就可以达到 O ( 树高 ) O(\text{树高}) O(树高) 的复杂度了吗?
可能不是这样。设想一组数据,令插入的第 i i i 个节点为 i i i,BST 便会退化为 O ( n 2 ) O(n^2) O(n2),长这样:

思路

为了弥补 BST 的各种劣势,聪明的 OIers 发明了平衡树。
对于上面卡掉 BST 的样例,平衡树的一种画法长这样:

可以看出来,平衡树是非常平衡的。
平衡树的重要处理就是维护其平衡性。
接下来介绍一下用来维护平衡树的平衡性质的两种操作——左旋( Zag \text{Zag} Zag)和右旋( Zig \text{Zig} Zig

  • Zag \text{Zag} Zag
    如果有一个失衡子树长这样:

    需要将节点 q \text q q 旋转至节点 p \text p p,我们可以这样:

    注意到,其中序遍历是不变的。
  • Zig \text{Zig} Zig
    如果有一个失衡子树长这样:

    需要将节点 q \text q q 旋转至节点 p \text p p,我们可以这样:

    注意到,其中序遍历是不变的。

由于不同的平衡树对失衡子树的处理方式是不同的,所以这里不再赘述,可以去下方的文章学习。


数据结构参数
  • 单次修改时间复杂度: Θ ( log ⁡ n ) \Theta(\log n) Θ(logn)
  • 单次查询时间复杂度: Θ ( log ⁡ n ) \Theta(\log n) Θ(logn)
  • 空间复杂度: Θ ( n ) \Theta(n) Θ(n)

接下来是三种基本的平衡树:

  • AVL
  • Treap
  • Splay
http://www.hengruixuexiao.com/news/23543.html

相关文章:

  • 台州自助建站在线咨询营业推广方案怎么写
  • 如何做视频购物网站百度后台推广登录
  • 潍坊网站建设推广报价搜索引擎优化的七个步骤
  • 怎么用editplus做网站seo搜索引擎优化案例
  • 组织建设 湖南省直工会网站给公司做网站的公司
  • 这个网站的建设流程长春seo整站优化
  • 北京昌平网站建设360优化大师最新版下载
  • 工程项目编号查询系统seo技术介绍
  • 企业网站用香港空间seo推广排名
  • wap网站建设设计软文是什么东西
  • 怎么模板建站常见的网站推广方法有哪些
  • 在招聘网站做电话销售怎么样东营优化路网
  • 东莞网站系统后缀app拉新渠道
  • 重庆云阳网站建设价格新媒体营销六种方式
  • 微信公众号和网站建设方案整合营销传播
  • 网站开发有几种十大网络舆情案例
  • 中国万网网站建设过程长尾词挖掘工具
  • 北苑网站建设介绍网络营销的短文
  • 做网站编辑需要看什么书北京百度网讯人工客服电话
  • 深圳建设企业aso优化分析
  • 免费送网站建立一个网站需要多少钱
  • 政府网站的做百度网页高级搜索
  • 用 asp net 做 的网站2023年8月疫情爆发
  • 基本型电子商务网站seo优化一般包括哪些内容
  • 律师如何做网络推广青岛网络工程优化
  • 用dw做网站的过程推广平台排行榜
  • 极速网站制作精准营销的概念
  • 住房和城乡建设岗位评定网站长沙网络公司营销推广
  • 清河做网站哪儿好在线培训平台
  • 山西做网站哪个好seo赚钱方法大揭秘