树,二叉树,查找算法总结

树,二叉树,查找算法总结

一.思维导图

树,二叉树,查找算法总结

树,二叉树,查找算法总结

二.重要概念的笔记

1. 树的基本术语

1.树中一个结点的子结点个数称为该结点的度

树中结点的最大度数称为树的度

2.度大于 0 的结点称为 分支结点(又称为非终端结点)。

度为 0 的(没有子女结点)的结点称为叶子结点(又称为终端结点)。

在分支结点中,每个结点的分支树就是该结点的度。

3.树中两个结点之间的路径是由这两个结点之间所经过的结点序列构成的.

路径长度是路径上所经过的边的个数

注意:由于树中分支是有向的,即从双亲结点指向孩子结点,所以树中的路径是从上向下的,同一个 双亲, 结点的两个孩子结点之间不存在路径

4.结点的层次从树根开始定义,根结点为第 1 层,它的子结点为第2 层,依次类推。

结点的深度是从根结点开始自顶向下逐层累加的。

结点的高度是从叶结点开始自底向上逐层累加的。

树的高度(又称为深度)是树中结点的最大层数。

2. 树的性质

  1. 树中的结点数等于所有结点的度数加1 。
  2. 度为 m 的树中第 i 层上至多有 m^(i-1) 个结点( i >= 1)。
  3. 高度为 h 的 m 叉树至多有 (m^h -1)/(m-1)个结点。
  4. 具有 n 个结点的 m 叉树的最小高度为 logm(n(m-1)+1) 。

3. 树的存储

1.双亲表示法:求父节点方便。
2.孩子表示法:求子节点方便。
3.孩子兄弟表示法:方便实现树和二叉树的相互转换。

4. 二叉树的性质

1.在二叉树的第i层上至多有2^(i-1)个结点(i>0)。
2.深度为k的二叉树至多有2^k-1个结点(k>0)。
3.对于任意一棵二叉树,如果其叶结点为N0,而度数为2的结点总数为N2,则N0=N2+1。
4.具有n个结点的完全二叉树的深度必为 log(2n)+1。
5.对完全二叉树,若从上至下、从左只右编号,则编号为i的节点,其左孩子编号必为2i,其有孩子编号必为2i+1;其双亲的编号必为i/2(i=1时为根 除外)。

5. B树

一个M阶的B树具有如下几个特征:

  1. 定义任意非叶子结点最多只有M个儿子,且M>2;
  2. 根结点的儿子数为[2, M];
  3. 除根结点以外的非叶子结点的儿子数为[M/2, M],向上取整;
  4. 非叶子结点的关键字个数=儿子数-1;
  5. 所有叶子结点位于同一层;
  6. k个关键字把节点拆成k+1段,分别指向k+1个儿子,同时满足查找树的大小关系。

6. B+树

m阶的B+树的特征:

  1. 有n棵子树的非叶子结点中含有n个关键字(B树是n-1个),这些关键字不保存数据,只用来索引,所有数据都保存在叶子节点(B树是每个关键字都保存数据)。
  2. 所有的叶子结点中包含了全部关键字的信息,及指向含这些关键字记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接。
  3. 所有的非叶子结点可以看成是索引部分,结点中仅含其子树中的最大(或最小)关键字。
  4. 通常在B+树上有两个头指针,一个指向根结点,一个指向关键字最小的叶子结点。
  5. 同一个数字会在不同节点中重复出现,根节点的最大元素就是B+树的最大元素。

B+树相比于B树的查询优势:

  1. B+树的中间节点不保存数据,所以磁盘页能容纳更多节点元素,更“矮胖”;
  2. B+树查询必须查找到叶子节点,B树只要匹配到即可不用管元素位置,因此B+树查找更稳定(并不慢);
  3. 对于范围查找来说,B+树只需遍历叶子节点链表即可,B树却需要重复地中序遍历,

7. 哈希冲突的解决方法:

  1. 开放定址法:
    线性探测法: 冲突发生时,顺序查看表中下一单元,直到找出一个空单元或查遍全表。
    二次探查法: 冲突发生时,在表的左右进行跳跃式探测,比较灵活。

  2. 拉链法:将所有关键字为同义词的结点链接在同一个单链表中。优点:
    拉链法处理冲突简单,且无堆积现象,即非同义词决不会发生冲突,因此平均查找长度较短。
    由于拉链法中各链表上的结点空间是动态申请的,故它更适合于造表前无法确定表长的情况。
    在用拉链法构造的散列表中,删除结点的操作易于实现。只要简单地删去链表上相应的结点即可。

三.疑难问题及解决方案

平衡二叉树刚开始构建的总会出错,不是很理解四种类型的构建方法,在老师讲解和练习下,已经可以熟练掌握。

  • 在结点的左孩子的左子树中插入数据(LL)
  • 在结点的右孩子的右子树中插入数据(RR)
  • 在结点的左孩子的右子树中插入数据(LR)
  • 在结点的右孩子的左子树中插入数据(RL)

对于LL型的情况,要使用右旋来解决,将失衡点右旋到其左孩子的右孩子的位置,失衡点的左子树更新为其原来左孩子的右子树。

树,二叉树,查找算法总结
树,二叉树,查找算法总结

对于RR型的情况,要使用左旋来解决,将失衡点左旋到其右孩子的左孩子的位置,失衡点的右子树更新为其原来右孩子的左子树。

树,二叉树,查找算法总结
树,二叉树,查找算法总结

对于LR型的情况,要使用先对失衡点的左孩子进行左旋,然后再对失衡点进行右旋来解决。

树,二叉树,查找算法总结
树,二叉树,查找算法总结

对于RL型的情况,要使用先对失衡点的右孩子进行右旋,然后再对失衡点进行左旋来解决。

树,二叉树,查找算法总结
树,二叉树,查找算法总结
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114448.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月6日 下午7:00
下一篇 2021年10月6日 下午7:00


相关推荐

  • Springboot源码结构预览「建议收藏」

    Springboot源码结构预览「建议收藏」系列文章目录Springboot学习系列一、Springboot源码结构预览二、Springboot运行原理三、Springboot源码流程构造分析四、Springboot运行流程构造分析五、SpringbootWeb应用源码解析文章目录系列文章目录概述二、Springboot源码1.源码获取2.源码调试3.目录结构3.目录结构总结学习目标:学习内容:学习时间:学习产出:概述Springboot源码获取、调试、目录结构、设计理念、整体架构。二、Springboot源码1.源

    2022年6月3日
    38
  • pytorch转tensorflow_语义分割样本不均衡

    pytorch转tensorflow_语义分割样本不均衡憨批的语义分割重制版7——TF2搭建自己的Unet语义分割平台注意事项学习前言什么是Unet模型代码下载Unet实现思路一、预测部分1、主干网络介绍2、加强特征提取结构3、利用特征获得预测结果二、训练部分1、训练文件详解2、LOSS解析训练自己的Unet模型注意事项这是重新构建了的Unet语义分割网络,主要是文件框架上的构建,还有代码的实现,和之前的语义分割网络相比,更加完整也更清晰一些。建议还是学习这个版本的Unet。学习前言还是快乐的pytorch人。什么是Unet模型Unet是一个优秀

    2022年8月21日
    10
  • Linux下的动态库和静态库详解

    Linux下的动态库和静态库详解动态库和静态库文章目录动态库和静态库静态库与动态库的概念理解动静态库如何打包动静态库与如何使用动静态库如何制作打包动态库为什么我们要使用别人 一般是顶尖的工程师写的 的代码 为了开发效率和鲁棒性 健壮性 如何使用别人的功能 1 库 2 开源代码 3 基本的网络功能调用 各自网络接口 语音识别 库一般分为动态库和静态库 动态库一般的命名为 libc so 静态库一般的命名为 libc a 去掉前缀 lib 去掉 之后的内容 剩下的就是库的名字 这里就是 c 库 生成可执行程序的方式有两种 动态链接和

    2026年3月16日
    2
  • uIP协议栈分析_协议栈

    uIP协议栈分析_协议栈转载地址:http://blog.sina.com.cn/s/blog_abd39cc70101fj1f.htmluIP特性uIP协议栈往掉了完整的TCP/IP中不常用的功能,简化了通讯流程,但保存了网络通讯必须使用的协议,设计重点放在了IP/TCP/ICMP/UDP/ARP这些网络层和传输层协议上,保证了其代码的通用性和结构的稳定性。由于uIP协议栈专门为嵌进式系统而设计,因此还具有…

    2022年8月30日
    9
  • ■ Android 集成环信android.support.v4.view不存在

    ■ Android 集成环信android.support.v4.view不存在

    2021年3月12日
    166
  • 编译期assert函数

    编译期assert函数编译期 assert 函数的目的在于当条件不满足时 阻止编译 从而防止错误的逻辑通过编辑 而运行期 assert 的目的在于运行时发现条件不满足时 产生一个 Debug 事件 DebugBreak 从而让调试器停下来方便用户检查原因 nbsp 需求描述有些比较关系 我们期望在编译期就能确保正确 需求情形 比如 A B 我们要求编译期就能保证 AB 否则编译不能通过 很明显 如果使用普通

    2026年3月16日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号