应用二叉树的遍历操作来实现判断两棵二叉树是否相等的操作_javascript进阶必备的二叉树知识...

2211eb3d10ddd67b8fbbee72195313a4.png

前言

每当放完小长假,我都会习惯性的反思和复盘一下自己的技术,尤其是端午节。为什么我会写二叉树的文章呢?其实这涉及到程序员的一个成长性的问题。对于0-3年前端程序员来说,可能很少有机会涉及到数据结构和算法的工作中,除非去大厂或者做架构相关的工作。但是很多工作2-3年的前端工程师,业务工作已经相对熟悉了,各种技术或多或少也都使用过,那么在这个阶段,对于每个有追求的程序员,是不是应该突破一下自己的技术瓶颈,去研究一些更深层次的知识呢?没错,这个阶段我们最应该了解的就是数据结构算法设计模式相关的知识,设计模式算法笔者在之前的文章中已经系统的总结过了,感兴趣的可以学习了解一下。

接下来笔者就系统的总结一下二叉树相关的知识,并且通过实际代码一步步来带大家实现一个二叉搜索树

二叉树介绍

二叉树(Binary tree)是树形结构的一个重要类型。许多实际问题抽象出来的数据结构往往是二叉树形式,即使是一般的树也能简单地转换为二叉树,而且二叉树的存储结构及其算法都较为简单,因此二叉树显得特别重要。二叉树特点是每个结点最多只能有两棵子树,且有左右之分

8742e24416928be4a62fbdaace140b7e.png

二叉树中的节点最多只能有两个子节点:左侧子节点右侧子节点。我们接下来主要来实现一个二叉搜索树(BST)。它是二叉树的一种,但是只允许你在左侧节点存储比父节点小的值,在右侧节点存储比父节点大(或者等于)的值。如下图:

cad536662a1357456db405e8a465315e.png

接下来我们就一起实现一下BST树。

实现一个二叉搜索(BST)树

在实现之前,我们需要先分析一下BST(二叉搜索)树。我们要想构建一棵实用的树,我们需要节点方法,如下图所示:

6ee1090647140fbc13c271e7213f877c.png

我们先实现一个基类,如下:

function 

我们按照上图的二叉搜索树的结构组织方式,来实现二叉树的基本方法。

// 插入

其中insertNode方法用来判断在根节点不为空时的执行逻辑,具体代码如下:

function 

以上代码即实现了BST的插入部分逻辑,具体使用方式如下:

let 

以上代码生成的二叉树结构如下:

bd1e42b26aa6869ee9ee7e0ffb08dfd4.png

树的遍历

树的遍历是指访问树的每个节点并对它们进行某种操作的过程。具体分为中序遍历先序遍历后序遍历。接下来我会一一介绍给大家。

中序遍历

中序遍历是一种以从最小到最大的顺序访问所有节点的遍历方式,具体实现如下:

this

具体遍历过程如下图所示:

26c3f76d3608271b726a472a03f6b26c.png

先序遍历

先序遍历是以优先于后代节点的顺序访问每一个节点。具体实现如下:

this

具体遍历如下图所示:

c5c1882a06c8cb69c67b36fce98d1018.png

后序遍历

后序遍历是先访问节点的后代节点,再访问节点本身。。具体实现如下:

this

具体遍历顺序如下图所示:

8a56fa46023368e4183d4fe86953127a.png

树的搜索

我们一般的搜索会有最值搜索(也就是最大值,最小值,中值)和对特定值的搜索,接下来我们就来实现它们。

搜索特定的值

在BST树中搜索特定的值,具体实现如下:

this

实现逻辑也很简单,这里大家可以研究一下。

搜索最小值

由二叉树的结构特征我们可以发现,二叉树的最左端就是最小值,二叉树的最右端就是最大值,所以我们可以通过遍历来找到最小值,代码如下:

this

搜索最大值

和求最小值一样,最大值也可以用类似的方法,代码如下:

this

移除节点

移除BST中的节点相对来说比较复杂,需要考虑很多情况,具体情况如下: 1. 移除一个叶节点

1d2b7640120b05febb148accf77a99b3.png

2. 移除有一个左侧或右侧子节点的节点

344fd6dd0dca69e7c3e296818267bf53.png

3. 移除有两个子节点的节点

ad6348161b2bc24d4aaf30a31dc92958.png

了解了上述3种情况之后我们开始实现删除节点的逻辑:

this

至此,一棵完整的搜索二叉树就实现了,是不是很有成就感呢?本文的源码以上传至笔者的github,感兴趣的朋友可以感受一下。

二叉树的应用

二叉树一般可以用来: 生成树结构 数据库的搜索算法 利用二叉树加密 计算目录和子目录中所有文件的大小, 打印一个结构化的文档 在游戏中用来做路径规划等

扩展

其实的类型还有很多种,这些不同类型的树在计算机中有很广泛的用途,比如红黑树B树自平衡二叉查找树空间划分树散列树希尔伯特R树等,如果对这些树敢兴趣的朋友可以深入研究一下,毕竟对自己未来的技术视野还是很有帮助的。

最后

如果想学习更多前端技能,实战学习路线, 欢迎在《趣谈前端》专栏学习讨论,共同探索前端的边界。

参考文献

二叉树 - https://baike.baidu.com/item/%E4%BA%8C%E5%8F%89%E6%A0%91

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值