二叉树的问题分析
二叉树的操作效率较高,但是也存在问题, 请看下面的二叉树
1)
二叉树需要加载到内存的,如果二叉树的节点少,没有什么问题,但是如果
二叉
树的节点很多
(
比如
1
亿
)
, 就存在如下问题
:
2)
问
题
1
:在构建二叉树时,需要多次进行
i/o
操作
(
海量数据存在数据库或文件中
)
,节点海量,构建二叉树时,速度有影响
3)
问题
2
:节点海量,
也
会造成二叉树的高度很大,会降低操作
速
度
.
多叉树
1)
在
二叉树中,每个节点
有数
据
项,
最多有两个子节点。如果
允许每个节点可以有更多的数据项和更多的子节点
,就是
多叉树(
multiway tree
)
2)
2-3
树,
2-3-4
树就是多叉树,多叉树通过重新组织节点,减少树的高度,能对二叉树进行优化。
3)
举
例说明
(
下面
2-3
树就是
一
颗多叉树
)
![](https://i-blog.csdnimg.cn/blog_migrate/7a9521b2052334bdff186ce5258abe0e.png)
2-3树基本介绍
2-3树是最简单的B树结构, 具有如下特点:
1)
2-3
树的所有叶子节点都在同一层
.(
只要是
B
树都满足这个条件
)
2)
有两个子节点的节点叫二节点,二节点
要么
没有子节点,要么有两个子节点
.
●
3)
有
三
个
子节点的节点
叫三节
点
,三节点要么没
有子节
点,要么有三个
子节
点
.
4)
2-3
树是由二节点和三节点构成的树。
2-3树应用案例
将数列{16, 24, 12, 32, 14, 26, 34, 10, 8, 28, 38, 20} 构建成2-3树,并保证数据插入的
大小顺序。(演示一下构建2-3树的过程.)
插入规则:
1)
2-3
树的所有叶子节点都在同一层
.(
只要是
B
树都满足这个条件
)
2)
有两个子节点的节点叫二节点,二节点要么没有子节点,要么有两个子节点
.
●
3)
有三个子节点的节点叫三节点,三节点要么没有子节点,要么有三个子节
点
4)
当
按照规则插入一个数到某个节点时
,不能满足上面三个要求,就需要拆,先向上拆,如果上层满,则拆本层,拆
后仍然需要满足上面
3
个条件。
5)
对于三节点的子树的值大小仍然
遵守
(BST
二叉排序树
)
的规则