求解算法

2021-10-14 17:04:02 +08:00
 SpiritLingPub

原文档在这: https://spiritling.notion.site/bac38b7879434371a9e3379a2682648f

将一个一维数组转为树形结构,多层次多根结点,只根据缩进来处理父子关系,而不是通过 parentId 来处理。

833 次点击
所在节点    算法
2 条回复
yidinghe
2021-10-14 17:30:16 +08:00
1 、首先定义一个节点类,包含值和子节点列表;
2 、然后建一个 map,保存"缩进 => 节点"对应关系,
3 、然后遍历数组,得到每个元素的缩进和值:
3.1 、新建节点对象,将值放入节点,
3.2 、将该节点放进 map (对于已有的值也直接替换)
3.3 、如果不是根节点,则从 map 中找上级节点,将该节点加到子节点里面去。

遍历完后即可转为树结构。
yidinghe
2021-10-14 17:32:24 +08:00
对于“多根节点”,只需在 map 中预先建一个缩进为 -1 的“虚拟根节点”即可。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/807847

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX