头条面试题:计算目录树的深度

前端迷

共 556字,需浏览 2分钟

 ·

2020-09-12 08:18

题目:前端在后台管理系统经常会用到目录树,求下面目录tree的高度。

得出depth即为树的高度得出depth即为树

const tree = {
  name'root',
  children: [
    { name'叶子1-1' },
    { name'叶子1-2' },
    {
      name'叶子2-1',
      children: [{
        name'叶子3-1',
        children: [{
          name'叶子4-1'
        }]
      }]
    }
  ]
}

function getDepth(tree{
  let depth = 0

  if (tree) {
    let arr = [tree]
    let temp = arr
    while (temp.length) {
      arr = temp
      temp = []
      for (let i = 0; i < arr.length; i++) {
        if (arr[i].children && arr[i].children.length) {
          for (let j = 0; j < arr[i].children.length; j++) {
            temp.push(arr[i].children[j])
          }
        }
      }
      depth++
    }
  }
  return depth
}console.log(getDepth(tree)); //输出4
  1. 定义变量depth为0得出depth即为树的高度得出depth即为树
  2. 定义一个空数组temp,然后遍历tree,如果tree有children,就push到temp里面
  3. 开始while循环,如果temp长度不为0,depth++;如果temp长度为0,停止

如果还有更好的解法,欢迎评论区留言。

思路:

得出depth即为树的高度得出depth即为树

  1. 定义变量depth为0
  2. 定义一个空数组temp,然后遍历tree,如果tree有children,就push到temp里面
  3. 开始while循环,如果temp长度不为0,depth++;如果temp长度为0,停止
  4. 得出depth即为树的高度
    得出depth即为树的高度得出depth即为树的高度得出depth即为树的高度

如果还有更好的解法,欢迎评论区留言。

得出depth即为树的高度得出depth即为树

浏览 45
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报