【愚公系列】软考中级-软件设计师 018-数据结构(二叉树的分类)_软件评测师二叉树知识

  1. 哈夫曼树(Huffman Tree):用于数据压缩,根据数据出现的频率构建的二叉树,频率越高的节点离根节点越近。
  2. Trie树(前缀树):用于字符串的存储和搜索,每个节点代表一个字符串的字符,从根节点到叶子节点的路径表示一个完整的字符串。
  3. B树(B-Tree):一种平衡多路查找树,用于大规模数据的存储和检索,每个节点可以有多个子节点。

🚀一、二叉树的分类

🔎1.线索二叉树

线索二叉树是对二叉树进行加工,使其能够快速遍历所有节点。

在线索二叉树中,除了左右孩子指针,还添加了两个额外的指针:前驱指针和后继指针。这两个指针分别指向当前节点的前驱节点和后继节点。

对于一个二叉树来说,存在多种线索化方式。以下是两种常见的线索化方式:

  1. 前序线索二叉树:在前序遍历过程中进行线索化。对于每个节点,先处理其前驱指针,然后处理左子树,再处理右子树,最后处理后继指针。对于树中的第一个节点,其前驱指针为空,对于树中的最后一个节点,其后继指针为空。
  2. 中序线索二叉树:在中序遍历过程中进行线索化。对于每个节点,先处理其左子树,然后处理前驱指针,然后处理右子树,最后处理后继指针。对于树中的第一个节点,其前驱指针为空,对于树中的最后一个节点,其后继指针为空。

在线索二叉树中,通过前驱和后继指针,可以快速地找到节点的前驱节点和后继节点,从而实现快速遍历。

在这里插入图片描述

🦋1.1 案例

假设有以下二叉树:

      1
    /   \
   2     3
  / \   / \
 4   5 6   7

对这棵二叉树进行中序线索化,得到的线索二叉树如下所示:

   4 - 2 - 5 - 1 - 6 - 3 - 7

在线索二叉树中,每个节点的左右孩子指针被替换为前驱和后继指针。

在这个例子中,节点1的左前驱指针指向节点5,右后继指针指向节点6;节点2的左前驱指针指向节点4,右后继指针指向节点1;节点3的左前驱指针指向节点6,右后继指针指向节点7;节点4的左前驱指针指向节点2,右后继指针指向节点5;节点5的左前驱指针指向节点4,右后继指针指向节点1;节点6的左前驱指针指向节点1,右后继指针指向节点3;节点7的左前驱指针指向节点3,右后继指针为空。

通过线索化后的二叉树,可以快速地找到每个节点的前驱和后继节点,从而实现快速的中序遍历。

🔎2.最优二叉树

最优二叉树,也称为哈夫曼树,是一种特殊的二叉树结构,常用于编码和解码的应用中。

最优二叉树的特点是,频率高的节点离根节点较近,频率低的节点离根节点较远。通过这种方式,可以实现最小化编码的平均长度,从而达到最优的压缩效果。

构建最优二叉树的基本思路是,首先根据每个节点的权重(即出现频率)进行排序,然后选择权重最小的两个节点作为左右子节点,生成一个新的父节点,并将父节点的权重设置为左右子节点的权重之和。重复这个过程,直到所有节点构建成一棵树。

最优二叉树可以应用在哈夫曼编码中,通过树的路径来表示字符的编码,使得频率高的字符编码较短,频率低的字符编码较长,从而实现压缩数据的效果。

相关概念如下:

  • 路径:树中一个结点到另一个结点之间的通路。
  • 结点的路径长度:路径上的分支数目。
  • 树的路径长度:根节点到达每一个叶子节点之间的路径长度之和。
  • 权:节点代表的值。
  • 结点的带权路径长度:该结点到根结点之间的路径长度乘以该节点的权值。
  • 树的带权路径长度(树的代价):树的所有叶子节点的带权路径长度之和。

在这里插入图片描述
哈夫曼树的求法:给出一组权值,将其中两个最小的权值作为叶子节点,其和作为父节点,组成二叉树,而后删除这两个叶子节点权值,并将父节点的值添加到该组权值中。重复进行上述步骤,直至所有权值都被使用完。

构造出的哈夫曼树中,所有初始给出的权值都作为了叶子节点,此时,求出每个叶子节点的带权路径长度,而后相加,就是树的带权路径长度,这个长度是最小的。
在这里插入图片描述

🦋2.1 案例

假设有以下节点集合:

节点A,出现的频率为5
节点B,出现的频率为3
节点C,出现的频率为2
节点D,出现的频率为1

为了构建最优二叉树,我们可以按照以下步骤进行:

  1. 将节点集合按照频率从小到大进行排序,得到排序后的节点集合:D,C,B,A。
  2. 从集合中选择频率最小的两个节点作为叶子节点,并创建一个新的节点作为它们的父节点,父节点的频率为子节点的频率之和。在我们的例子中,D和C被选择为叶子节点,它们的频率之和为3。
  3. 将新的父节点加入到集合中,并将集合重新排序。新的节点集合为:B,A,新的父节点。
  4. 重复步骤2和步骤3,直到集合中只剩下一个节点。
  5. 最后剩下的节点就是构建的最优二叉树的根节点。

根据上述步骤,我们可以得到如下的最优二叉树:

    B
   / \
  C   A
 /
D

在这里插入图片描述

🔎3.查找二叉树

查找二叉树,也称为二叉搜索树(Binary Search Tree,BST),是一种特殊的二叉树结构,它具有以下性质:

  1. 左子树上所有节点的值都小于根节点的值。
  2. 右子树上所有节点的值都大于根节点的值。
  3. 每个子树也必须满足上述两个性质。

由于这种特殊的性质,查找二叉树的结构非常便于查找和插入操作。当我们需要查找一个特定的元素时,可以通过比较当前节点的值与目标值的大小关系,根据二叉树的有序性质,可以在左子树或右子树中继续查找,直到找到目标元素或者遍历到叶子节点。

插入操作也非常简单,只需要在合适的位置创建一个新的节点,并调整树的结构以保持其有序性。

对于查找二叉树的时间复杂度,最好的情况下是O(logn),最坏的情况下是O(n),其中n是树中节点的个数。这取决于树的形状,如果树是高度平衡的,则查找的时间复杂度会相对较低,否则会退化为链表,导致查找时间复杂度上升。

需要注意的是,查找二叉树并不保证是平衡的,因此在某些情况下可能会导致树的不平衡,从而影响查找的效率。为了解决这个问题,可以使用平衡二叉树的变种,如红黑树或AVL树,来保持树的平衡性。

在这里插入图片描述

🔎4.平衡二叉树

平衡二叉树(Balanced Binary Tree),也称为AVL树,是一种特殊的二叉搜索树(Binary Search Tree),它的左子树和右子树的高度差不超过1,并且左子树和右子树都是平衡二叉树。

css

1,盒模型
2,如何实现一个最大的正方形
3,一行水平居中,多行居左
4,水平垂直居中
5,两栏布局,左边固定,右边自适应,左右不重叠
6,如何实现左右等高布局
7,画三角形
8,link @import导入css
9,BFC理解

js

1,判断 js 类型的方式
2,ES5 和 ES6 分别几种方式声明变量
3,闭包的概念?优缺点?
4,浅拷贝和深拷贝
5,数组去重的方法
6,DOM 事件有哪些阶段?谈谈对事件代理的理解
7,js 执行机制、事件循环
8,介绍下 promise.all
9,async 和 await,
10,ES6 的 class 和构造函数的区别
11,transform、translate、transition 分别是什么属性?CSS 中常用的实现动画方式,
12,介绍一下rAF(requestAnimationFrame)
13,javascript 的垃圾回收机制讲一下,
14,对前端性能优化有什么了解?一般都通过那几个方面去优化的?

区别
11,transform、translate、transition 分别是什么属性?CSS 中常用的实现动画方式,
12,介绍一下rAF(requestAnimationFrame)
13,javascript 的垃圾回收机制讲一下,
14,对前端性能优化有什么了解?一般都通过那几个方面去优化的?

[外链图片转存中…(img-owtYn3Sm-1719236286859)]

  • 24
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值