平铺树结构

let qs = [{
      value: 'A',
      children: [
        {
          value: 'B',
          children: [
            {
              value: 'D',
              children: [
                {
                  value: 'H',
                  children: []
                }
              ]
            },
            {
              value: 'E',
              children: []
            }
          ]
        },
        {
          value: 'C',
          children: [
            {
              value: 'F',
              children: []
            },
            {
              value: 'G',
              children: []
            }
          ]
        }
      ]
    }]

1、普通递归

let list = []
function flatten1(data){
      let stack = JSON.parse(JSON.stringify(data))
      stack.map((ele) => {
        list.push(ele)
        if (ele.children) {
          flatten1(ele.children)
        }
      })
      return list
    }

2、reduce

    function flatten2(data) {
      return data.reduce((prev, cur) => {
        prev.push(cur)
        if (cur.children) {
          prev.push(...flatten2(cur.children))
        }
        return prev
      }, [])
    }

3、模拟栈

function flatten3(data) {
      let list = []
      let stack = JSON.parse(JSON.stringify(data))
      while (stack.length) {
        // 栈顶结点出栈
        let node = stack.pop()
        list.push(node)
        if (node.children && node.children.length) {
          // 将候选顶点入栈,进行下一次循环
          stack.push(...node.children)
        }
      }
      return list
    }

前两个结果为​​​​​​​

最后一个结果为

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值