数据结构(树)基础,虚拟dom,树的类型,二叉树的类型

树的简介

一棵树有且只有一个根节点
每个节点有零到多个子节点
每个子节点有零到多个子节点
每个节点会保存节点的值
相邻的节点称为:邻居节点
没有子节点的节点称为:叶子节点
树的层数称为:树的高度
除了根节点以外,子节点以及它后续节点所形成的树称为:子树
树是应用最广泛的一种数据结构
比如:html dom,vertual dom结构

一般用于:

在这里插入图片描述

verual dom(虚拟dom)

所谓的 virtual dom,也就是虚拟节点。它通过 JSObject 对象模拟 DOM 中的节点,然后再通过特定的 render 方法将其渲染成真实的 DOM 节点。

https://blog.csdn.net/xiasohuai/article/details/100037640

树的分类

根据子节点数量的不同,分为:二叉树,三叉树 或者 多叉树

在这里插入图片描述
在这里插入图片描述

二叉树:

二叉树最为常见
每个节点最多有两个子节点

多叉树:

常见的为 字典树

字典树又叫前缀树,一般用来存储一些单词或数字,在查找的时候比较方便,由于相同前缀只存储一次,所以也是比较省空间

字典树是一棵树,一般用数组存储比较方便,从根节点出发根节点不存储字母,每遇到一个字母,先判断树上是不是已经有了,如果有了,就顺着这条路;如果没有新建立一条路径直到最后一个字母,这时候将末尾字母所在位置染色,表示这是末尾字母。所以,字典树是一棵多叉树
在这里插入图片描述

二叉树的类型

完全二叉树

每一层的节点都拥有两个子节点最后一层除外,并且最后一层空缺的节点必须右边左边必须填满
在这里插入图片描述

满二叉树

二叉树每个节点要么有两个子节点,要么没有子节点,不能只有一个子节点
在这里插入图片描述

完美二叉树

所有的节点都有两个子节点,最后一层都是叶子节点
在这里插入图片描述

标题平衡二叉树

平衡二叉树的定义并不是很严格不同的场景下有不同的定义

一个二叉树,如果大体上左右两棵子树看起来比较平衡,那么它就是平衡二叉树

有的定义是左右子树的每个节点的高度差不大于一
在这里插入图片描述

二叉搜索树

二叉树左子节点的值小于等于节点值小于 右子节点的值,并且 左节点 和 它后续节点的值 都 小于等于 该节点的值右节点 和它后续的值 都大于该节点的值

这样形成的树 方便进行搜索和排序,所以叫做二叉搜索树
在这里插入图片描述
在这里插入图片描述
对于 和节点相同的子节点 应该放在左边还是右边,不同的实现有不同的规定

自平衡二叉搜索树

在这里插入图片描述
这种树在 平衡二叉树和搜索二叉树 的基础上,会根据节点的插入和删除 自动保持平衡

常见的有:红黑树和AVL树

js的实现:
在这里插入图片描述
子节点(value,left,right)的类型都是TreeNode

value树的值left保存左子节点的引用right保存右子节点的引用

注意TreeNode是一个递归的类型
注意也是递归的结构

什么是递归类型

在计算机编程语言中,递归类型(又名:递归定义、隐含类型或隐含定义)是一种特殊的数据类型,它表示自身内部可能包含其它的同样类型的值。
https://baike.baidu.com/item/递归类型/2432721

因为树也是递归的结构,所以通过根节点可以找到所有的子节点类的剩余部分,可以定义和二叉树有关的操作

在这里插入图片描述

用的最多的应该是平衡二叉树有种特殊的平衡二叉树红黑树,查找、插入、删除的时间复杂度最坏为O(log n)

Java集合中的TreeSetTreeMapC++ STL中的set、map,以及Linux虚拟内存的管理都是通过红黑树实现
https://blog.csdn.net/fadbgfnbxb/article/details/88701343

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值