Javascript之“树“

简介: Javascript之“树“

一种分层数据的模型


前端工作中常见包括:DOM树,级联选择,树形控件


JS中没有树,但是可以用Object和Array构建树


树的常用操作:深度/广度优先遍历,先中后序遍历


1. 常用操作


DFS实现


  • 访问根节点


  • 对根节点的children挨个进行深度优先遍历


const tree = {
  val: 'a',
  children: [
    {
      val: 'b',
      children: [
        {
          val: 'c',
          children: []
        },
        {
          val: 'd',
          children: []
        }
      ]
    },
    {
      val: 'e',
      children: [
        {
          val: 'f',
          children: []
        },
        {
          val: 'g',
          children: []
        }
      ]
    }
  ]
}
const dfs = (root) => {
  console.log(root.val)
  root.children.forEach(dfs)
}
dfs(tree)


BFS实现


  • 新建一个队列,把根节点入队


  • 把对头出队并访问


  • 把对头的children挨个入队


  • 重复第二三步,直到队列为空


const tree = {
  val: 'a',
  children: [
    {
      val: 'b',
      children: [
        {
          val: 'c',
          children: []
        },
        {
          val: 'd',
          children: []
        }
      ]
    },
    {
      val: 'e',
      children: [
        {
          val: 'f',
          children: []
        },
        {
          val: 'g',
          children: []
        }
      ]
    }
  ]
}
const bfs = (root) => {
  const q = [root]
  while(q.length > 0) {
    const r = q.shift()
    console.log(r)
    r.children.forEach(item => q.push(item))
  }
}
bfs(tree)


二叉树的先中后序遍历(递归)


const bt = {
  val: 1,
  left: {
    val: 2,
    left: {
      val: 4,
      left: null,
      right: null
    },
    right: {
      val: 5,
      left: null,
      right: null,
    }
  },
  right: {
    val: 3, 
    left: {
      val: 6,
      left: null,
      right: null,
    },
    right: {
      val: 7,
      left: null,
      right: null,
    }
  }
}
// 先序遍历
const preorder = (root) => {
  if(!root) { return }
  console.log(root.val)
  preorder(root.left)
  preorder(root.right)
}
// 中序遍历
const inorder = (root) => {
  if(!root) { return }
  inorder(root.left)
  console.log(root.val)
  inorder(root.right)
}
// 后序遍历
const postorder = (root) => {
  if(!root) { return }
  postorder(root.left)
  postorder(root.right)
  console.log(root.val)
}


二叉树的先中后序遍历(非递归)


// 先序遍历
const preorder = (root) => {
  if(!root) { return }
  const stack = [root]
  while(stack.length) {
    const n = stack.pop()
    console.log(n.val)
    if( n.right ) stack.push(n.right)
    if( n.left ) stack.push(n.left)
  }
}
// 中序遍历
const inorder = (root) => {
  if(!root) { return }
  const stack = []
  let p = root
  while(stack.length || p) {
    while(p) {
      stack.push(p)
      p = p.left
    }
    const n = stack.pop()
    console.log(n.val)
    p = n.right
  }
}
// 后续遍历
const postorder = (root) => {
  if(!root) { return }
  const outputStack = []
  const stack = [root]
  while(stack.length) {
    const n = stack.pop()
    outputStack.push(n)
    if(n.left) stack.push(n.left)
    if(n.right) stack.push(n.right)
  }
  while(outputStack.length) {
    const n = outputStack.pop()
    console.log(n.val)
  }
}


2. 练习


二叉树的最大深度


二叉树的最小深度


二叉树的层序遍历


二叉树的中序遍历


路径总和

相关文章
|
4月前
|
算法 JavaScript
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
69 0
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
|
5月前
|
JavaScript 前端开发 算法
虚拟DOM是React的关键技术,它是个轻量的JS对象树,模拟实际DOM结构。
【6月更文挑战第27天】虚拟DOM是React的关键技术,它是个轻量的JS对象树,模拟实际DOM结构。当状态改变,React不直接修改DOM,而是先构建新的虚拟DOM树。通过 diff 算法比较新旧树,找到最小变更,仅更新必要部分,提高性能,避免频繁DOM操作。虚拟DOM还支持跨平台应用,如React Native。它优化了更新流程,简化开发,并提升了用户体验。
44 1
|
4月前
|
JavaScript
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
125 0
|
6月前
|
前端开发 JavaScript 算法
JavaScript 中实现常见数据结构:栈、队列与树
JavaScript 中实现常见数据结构:栈、队列与树
|
6月前
|
JavaScript
理解DOM树的加载过程(js的问题)
理解DOM树的加载过程(js的问题)
31 0
|
JavaScript
使用JS 实现二叉查找树(Binary Search Tree)
使用JS 实现二叉查找树(Binary Search Tree)
76 0
|
6月前
|
JSON JavaScript 前端开发
js(递归函数)实现树型菜单
js(递归函数)实现树型菜单
55 0
antd+js 目录树实现
antd+js 目录树实现
99 0
|
JavaScript 前端开发 程序员
《剑指 Offer(第 2 版)》树部分JavaScript题解
《剑指 Offer(第 2 版)》树部分JavaScript题解
《剑指 Offer(第 2 版)》树部分JavaScript题解
|
自然语言处理 JavaScript 前端开发
浏览器原理 21 # DOM树:JavaScript是如何影响DOM树构建的?
浏览器原理 21 # DOM树:JavaScript是如何影响DOM树构建的?
155 0
浏览器原理 21 # DOM树:JavaScript是如何影响DOM树构建的?