数据结构知识总结

news2025/1/11 19:41:10

二叉树

满二叉树

特性

所有叶子结点都集中在二叉树的最下面一层上,而且结点总数为:2^n-1 (n为层数 / 高度)
在这里插入图片描述





完全二叉树

特性

若设二叉树的高度为h,除第h层外,其他各层的节点数都达到最大个数,第h层有叶子节点,并且叶子节点都是从左到右依次排布。(堆为完全二叉树)

在这里插入图片描述





平衡二叉树

特性

空树或者左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一颗平衡二叉树。

在这里插入图片描述


作用

平衡二叉树最大的作用就是查找,AVL树的查找、插入和删除在平均和最坏情况下都是O(logn)





二叉搜索树

特性

若左子树不空,则左树上所有节点的值均小于或等于它的根节点的值。
若右子树不空,则右树上所有节点的值君大于或等于它的根节点的值。
左右子树也分别为二叉搜索树。

在这里插入图片描述





红黑树

特性

首先,红黑树是一个二叉搜索树,它在每个节点增加了一个存储位记录节点的颜色,可以是RED,也可以是BLACK;通过任意一条从根到叶子简单路径上颜色的约束,红黑树保证最长路径不超过最短路径的二倍,因而近似平衡(最短路径就是全黑节点,最长路径就是一个红节点一个黑节点,当从根节点到叶子节点的路径上黑色节点相同时,最长路径刚好是最短路径的两倍)

  1. 节点是红色或黑色。
  2. 根节点是黑色。
  3. 所有的叶子节点都是黑色。
  4. 红色节点的子节点都是黑色
    1. 红色节点的父节点都是黑色
    2. 从根节点到叶子节点的所有路径上不能有 2 个连续的红色节点
  5. 从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点。

在这里插入图片描述



为什么需要红黑树

对于二叉搜索树,如果插入的数据是随机的,那么它就是接近平衡的二叉树,平衡的二叉树,它的操作效率(查询,插入,删除)效率较高,时间复杂度是O(logN)。但是可能会出现一种极端的情况,那就是插入的数据是有序的(递增或者递减),那么所有的节点都会在根节点的右侧或左侧,此时,二叉搜索树就变为了一个链表,它的操作效率就降低了,时间复杂度为O(N),所以可以认为二叉搜索树的时间复杂度介于O(logN)和O(N)之间,视情况而定。那么为了应对这种极端情况,红黑树就出现了,它是具备了某些特性的二叉搜索树,能解决非平衡树问题,红黑树是一种接近平衡的二叉树(说它是接近平衡因为它并没有像AVL树的平衡因子的概念,它只是靠着满足红黑节点的5条性质来维持一种接近平衡的结构,进而提升整体的性能,并没有严格的卡定某个平衡因子来维持绝对平衡)。





B树

特性

B树是一个多路搜索树,每个节点可以存储多个关键字和对应的数据

一颗阶数为k(k>=2)的B树具有以下结构特点:

  • 根节点至少有1个关键字
  • 每个非叶子结点都包含k-1个元素和k个孩子,其中 m/2 <= k <= m ,m为树的高度
  • 每个节点中的元素从小到大排列,节点当中k-1个元素正好是k个孩子包含的元素的值域分划
  • 所有叶子节点位于相同的层级,并且都是空节点或者包含数据的节点

4阶B树


实际应用

  • 文件系统:B树常被用作文件系统的索引结构。它可以有效地管理大量的文件和目录,并支持快速的文件查找和访问。典型的例子包括Unix文件系统中的Inode索引和NTFS文件系统中的MFT(Master File Table)索引。

  • 数据库系统:B树是关系数据库管理系统中常见的索引结构之一。它被广泛用于构建数据库中的索引,以加快数据的检索速度。B树的平衡性和高效性使得它适用于存储大量数据的场景,并且能够支持范围查询、插入和删除操作。

  • 磁盘和存储系统:B树的结构特点使得它适用于管理存储和磁盘上的数据。B树的节点大小通常与磁盘块大小相匹配,可以减少磁盘访问次数,并提高数据的读写效率。

  • 搜索引擎:B树在搜索引擎中用于构建倒排索引,加速文档的搜索和检索。倒排索引存储了词汇表和每个词汇对应的文档列表,B树使得在大规模文档集合中进行高效的关键字搜索成为可能。



B树优缺点

  • B树优点:
    高效的查找:B树是一种多路搜索树,可以在具有大量数据的情况下快速查找目标元素。它的高度相对较低,因此查找操作的时间复杂度为O(log n),其中n是元素的数量。

    高度平衡:B树在插入和删除操作后能够自动保持平衡,使得树的高度相对稳定。这确保了各个节点之间的平衡性,避免了树的倾斜,提高了整体性能。

  • B树缺点:
    结构相对复杂,实现难度较大。

    内存占用:B树的节点通常比其他树结构的节点更大,因为它需要存储关键字和子节点的指针。

    节点的分裂和合并操作可能导致频繁的磁盘IO操作,影响性能。





B+树

特性

B+树是在B树基础上进行了改进和优化,具有以下结构特点:

  • B+树与B树的结构类似,但是所有数据都存储在叶子节点上,而非叶子节点只包含关键字范围(或称为分裂值)和指向子节点的指针
  • 非叶子节点的关键字范围与子节点一致(k = n,k为键树,n为子节点)
  • 所有叶子节点使用链表连接形成有序链表,提高了范围查询的效率。
  • 非叶子节点的关键字起到索引的作用,可以加速查找操作。



实际应用

  • 文件系统:B+树常被用于文件系统的元数据管理,如目录结构和文件索引,B+树可以快速定位和访问文件或目录,同时支持高效的范围查询和顺序访问。

  • 关系型数据库(经典MySQL):B+树通常用于关系型数据库的聚集索引和辅助索引。聚集索引决定了数据的物理存储顺序,而辅助索引加快了特定字段的查询速度。

  • 文件索引:B+树可以用于文件索引,特别是大规模文件存储系统中。它可以快速定位和访问文件块或数据块,提高文件系统的读写效率。

  • 日志结构化存储:B+树被应用于日志结构化存储(Log-Structured Storage)中,例如用于分布式文件系统和分布式数据库系统,B+树的顺序访问性能和范围查询能力使得它适合于处理大量写入操作和高效的数据恢复。



B+树优缺点

  • 优点:
    高效的范围查询:B+树的叶子节点形成有序链表,使得范围查询操作非常高效。通过遍历叶子节点链表,可以快速获取范围内的数据,适用于诸如区间查询等操作。

    顺序访问性能好:由于叶子节点形成有序链表,B+树对于顺序访问的性能较好。可以通过遍历叶子节点链表来按顺序获取数据,适用于排序、分页和顺序遍历等操作。

    高度相对较低:B+树的节点可以存储多个关键字,因此相比于其他平衡树结构,B+树的高度相对较低。这降低了磁盘访问的次数,提高了数据的访问效率。

    支持大规模数据集:B+树适用于大规模数据集的索引,具有良好的扩展性。它可以有效地处理大量的数据和高并发访问,适合在数据库和文件系统等场景中使用。

    有序性:B+树的关键字在节点内部以有序方式存储,这对于范围查询、排序和范围分割等操作非常有利。

  • 缺点:
    写操作相对复杂:相比于其他树结构,B+树的插入和删除操作可能稍显复杂。因为插入和删除可能触发节点的分裂和合并,需要进行额外的调整操作。

    空间开销较大:B+树的节点需要存储关键字和指针,因此在存储空间上会有一定的开销。尤其是对于小规模数据集来说,B+树可能会占用更多的内存空间。



B树与B+树的对比(区别)

关键字位置:在B树中,所有关键字都存储在节点中,并且叶子节点和非叶子节点具有相同的结构。而在B+树中,所有关键字都存储在叶子节点中,非叶子节点只包含关键字的范围和指向子节点的指针。

叶子节点结构:B树的叶子节点存储关键字和对应的数据(或指向数据的指针),而B+树的叶子节点只存储关键字和指向数据的指针。叶子节点通过指针连接形成有序链表,而非叶子节点只包含关键字范围和指向子节点的指针。

范围查询和顺序访问:由于B+树的叶子节点形成有序链表,B+树在范围查询和顺序访问方面具有优势。B树在这些操作上的性能相对较差,需要进行更多的节点访问。

高度:由于B+树的关键字全部存储在叶子节点中,非叶子节点只包含关键字的范围和指向子节点的指针,B+树的高度相对较低。而B树的高度相对较高,因为关键字存储在节点中,非叶子节点和叶子节点具有相同的结构。





本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1535173.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Windows 设置多显示器显示

Windows 设置多显示器显示 1. Windows 7 设置 HDMI 输出2. Windows 11 设置多显示器显示References 1. Windows 7 设置 HDMI 输出 2. Windows 11 设置多显示器显示 ​​​ References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

MAC本安装telnet

Linux运维工具-ywtool 目录 1.打开终端1.先安装brew命令2.写入环境变量4.安装telnet 1.打开终端 访达 - 应用程序(左侧) - 实用工具(右侧) - 终端 #注意:登入终端用普通用户,不要用MAC的root用户1.先安装brew命令 /bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/H…

Android Studio实现内容丰富的安卓校园助手班级成绩天气管理

获取源码请点击文章末尾QQ名片联系&#xff0c;源码不免费&#xff0c;尊重创作&#xff0c;尊重劳动 1.开发环境 android stuido3.6 jak1.8 eclipse mysql tomcat 2.功能介绍 安卓端&#xff1a; 1.注册登录 2.校园公告 3.课程列表 4.成绩列表&#xff0c;天气列表 5.个人中心…

python + tensorflow 开局托儿所自动点击脚本

python开局托儿所自动点击脚本 屏幕截图图片数字识别消除算法自动点击 屏幕截图 python 屏幕截图可以使用pyautogui或者PIL。我使用的是PIL中的ImageGrab(要授权)。 image ImageGrab.grab(bbox(0, 0, tool.static_window_width, tool.static_window_height)) image np.arra…

人脸表情识别系统项目完整实现详解——(三)训练MobileNet深度神经网络识别表情

摘要&#xff1a;之前的表情识别系统升级到v3.0版本&#xff0c;本篇博客详细介绍使用PyTorch框架来构建并训练MobileNet V3模型以进行实现表情识别&#xff0c;给出了完整实现代码和数据集可供下载。从构建数据集、搭建深度学习模型、数据增强、早停等多种技术&#xff0c;到模…

Django日志(一)

一、概念与配置 1.1、概述 日志是程序员经常在代码中使用快速和方便的调试工具。它在调试方面比print更加的优雅和灵活 而且日志记录对于调试很有用,可以提供更多,更好的结构化,有关应用程序的状态和运行状况的信息 Django框架的日志通过python内置的logging模块实现的,可…

inputStream.avaliable()方法网络操作读取不全BUG

一、问题描述 公司有个需求&#xff0c;就是调用方&#xff08;我&#xff09;需要把pdf文件转为Base64字符串作为参数传递为被调用方&#xff0c;以下是大致转换过程&#xff1a; URL url new URL("http://xxxx.pdf");HttpURLConnection uc (HttpURLConnection) …

XR“黑话”

MTP&#xff08;Motion-To-Photon Latency&#xff09;&#xff1a;实际人体发生运动到图像显示到屏幕上的时间延迟。早期一些vr产生晕动症的主要原因。 ATW&#xff08;Asynchronous Timewarp&#xff09;&#xff1a;主要解决两个问题&#xff0c;一是延迟&#xff0c;二是补…

R语言Meta分析核心技术:回归诊断与模型验证

R语言作为一种强大的统计分析和绘图语言&#xff0c;在科研领域发挥着日益重要的作用。其中&#xff0c;Meta分析作为一种整合多个独立研究结果的统计方法&#xff0c;在R语言中得到了广泛的应用。通过R语言进行Meta分析&#xff0c;研究者能够更为准确、全面地评估某一研究问题…

Django日志(三)

内置TimedRotatingFileHandler 按时间自动切分的log文件,文件后缀 %Y-%m-%d_%H-%M-%S , 初始化参数: 注意 发送邮件的邮箱,开启SMTP服务 filename when=h 时间间隔类型,不区分大小写 S:秒 M:分钟 H:小时 D:天 W0-W6:星期几(0 = 星期一) midnight:如果atTime未指定,…

Avue框架实现图表的基本知识 | 附Demo(全)

目录 前言1. 柱状图2. 折线图3. 饼图4. 刻度盘6. 仪表盘7. 象形图8. 彩蛋8.1 饼图8.2 柱状图8.3 折线图8.4 温度仪表盘8.5 进度条 前言 以下Demo&#xff0c;作为初学者来说&#xff0c;会相应给出一些代码注释&#xff0c;可相应选择你所想要的款式 对于以下Demo&#xff0c…

管理类联考–复试–英文面试–问题–WhatWhyHow--纯英文汇总版

文章目录 Do you have any hobbies? What are you interested in? What do you usually do in your spare time? Could you tell me something about your family&#xff1f; Could you briefly introduce your family? What is your hometown like? Please tell me so…

HTTPS 协议原理

目录 HTTPS VS HTTP HTTPS是什么 概念准备 常见的加密方式 对称加密 一个简单的对称加密例子 非对称加密 数据摘要&&数据指纹 数字签名 HTTPS 的工作过程探究 方案1-只使用对称加密 方案2-只使用非对称加密 方案3-双方都使用非对称加密 方案4-非对称加密…

01、Lua 入门教程

Lua 入门教程 Lua是一种轻量小巧的脚本语言&#xff0c;用标准C语言编写并以源代码形式开放&#xff0c; 其设计目的是为了嵌入应用程序中&#xff0c;从而为应用程序提供灵活的扩展和定制功能。 Lua是巴西里约热内卢天主教大学&#xff08;Pontifical Catholic University of…

搭建jumpserver堡垒机

堡垒机介绍&#xff1a; jumpServer是一款开源的堡垒机&#xff08;Bastion Host&#xff09;和会话管理系统&#xff0c;用于管理和保护企业的服务器和网络设备。它提供了安全的远程访问和会话审计功能&#xff0c;帮助组织实现对敏感系统和资源的集中管理和控制。 功能&…

VMware设备VMnet0上的网桥因桥接的以太网接口关闭而暂时停止运行(此虚拟机可能无法与主机或网络中的其他计算机通信,不显示ip)

文章目录 VMware设备VMnet0上的网桥因桥接的以太网接口关闭而暂时停止运行&#xff08;此虚拟机可能无法与主机或网络中的其他计算机通信,不显示ip&#xff09;解决办法如下1、查看本机电脑网络信息&#xff0c;看看用的是哪个网卡2、点击Vmware左上角的编辑&#xff0c;打开虚…

【JS】JavaScript 中的原型与原型链

JavaScript 中的原型与原型链 原型1 函数中 prototype 指向原型对象2 对象中 __proto__ 指向原型对象3 原型对象中 constructor 指向构造函数4 __proto__ 与 [[Prototype]] 的关系5 所有非空类型数据&#xff0c;都具有原型对象6 new运算符做了哪些事情 原型链1 举个栗子1.1 直…

[linux]--关于进程概念(下)

目录 孤儿进程 环境变量 将程序放到PATH路径下 设置PATH环境变量 设置别名 环境变量相关的命令 环境变量的组织方式​编辑 通过系统调用获取环境变量 环境变量通常是具有全局属性的 进程优先级 查看系统进程 用top命令更改已存在进程的nice&#xff1a; 程序地址空…

mac下Appuim环境安装-持续更新中

参考资料 Mac安装Appium_mac电脑安装appium-CSDN博客 安卓测试工具&#xff1a;Appium 环境安装&#xff08;mac版本&#xff09;_安卓自动化测试mac环境搭建-CSDN博客 1. 基本环境依赖 1 node.js 2 JDK&#xff08;Java JDK&#xff09; 3 Android SDK 4 Appium&#x…

数据库系统概论-第14章 大数据管理

14.1 大数据概述 14.2 大数据的应用 14.3 大数据管理系统 14.4 小结