【JavaScript】数据结构之树

什么是树形结构?

  • 一种分层数据的抽象模型,用来分层级关系的。
  • 虚拟dom它所组织的那个数据原理就是树形结构

深度优先搜索(遍历)- 递归

  • 从根出发,尽可能深的搜索树的节点
  • 技巧
    • 访问根节点
    • 对根节点的children挨个进行深度优化搜索

广度优先搜索(遍历)

  • 从根出发,优先访问离根节点最近的节点
  • 技巧
    • 新建一个队列,把根节点入队
    • 把队头出队
    • 把队头的children挨个入队
    • 重复上面二三步骤,直到队列为空为止

树 - 多叉树

  • dom结构是典型的多叉树

树 - 二叉树

  • 前序遍历 & 先序遍历
    • 规则:根 左 右
    • 先从根出发 > 拿左子树的左 > 拿左子树的右,等左边都结束 > 再拿右子树的左 > 拿右子树的右
    • 可以通过递归算法实现,也可以通过迭代算法(栈)实现。
  • 中序遍历
    • 规则:左 根 右
  • 后序遍历
    • 规则:左 右 根

leetcode 习题

二叉树习题

相关推荐
大母猴啃编程43 分钟前
数据结构---非线性--树
c语言·数据结构·学习·算法·青少年编程
码农探知1 小时前
鹏哥C语言自定义笔记重点(67-)
c语言·数据结构
蠢蠢的打码3 小时前
8584 循环队列的基本操作
数据结构·c++·算法·链表·图论
无问8175 小时前
数据结构-排序(冒泡,选择,插入,希尔,快排,归并,堆排)
java·数据结构·排序算法
Lenyiin5 小时前
《 C++ 修炼全景指南:十 》自平衡的艺术:深入了解 AVL 树的核心原理与实现
数据结构·c++·stl
slandarer6 小时前
MATLAB | R2024b更新了哪些好玩的东西?
java·数据结构·matlab
king_machine design6 小时前
matlab中如何进行强制类型转换
数据结构·算法·matlab
头发尚存的猿小二6 小时前
树——数据结构
数据结构·算法
紫钺-高山仰止7 小时前
【Matlab】matlab 结构体使用方法
数据结构·算法·matlab
shan_shmily7 小时前
算法知识点———并查集
数据结构·算法