知乎 校招 笔试
2023-03-04 15:00
算法
- 数组对象转树结构
ts
const a = [
{ id: 12, parent_id: 1, name: '朝阳区' },
{ id: 241, parent_id: 24, name: '田林街道' },
{ id: 31, parent_id: 3, name: '广州市' },
{ id: 13, parent_id: 1, name: '昌平区' },
{ id: 2421, parent_id: 242, name: '上海科技绿洲' },
{ id: 21, parent_id: 2, name: '静安区' },
{ id: 242, parent_id: 24, name: '漕河泾街道' },
{ id: 22, parent_id: 2, name: '黄浦区' },
{ id: 11, parent_id: 1, name: '顺义区' },
{ id: 2, parent_id: 0, name: '上海市' },
{ id: 24, parent_id: 2, name: '徐汇区' },
{ id: 1, parent_id: 0, name: '北京市' },
{ id: 2422, parent_id: 242, name: '漕河泾开发区' },
{ id: 32, parent_id: 3, name: '深圳市' },
{ id: 33, parent_id: 3, name: '东莞市' },
{ id: 3, parent_id: 0, name: '广东省' }
]
function arrayToTree(list, root) {
const result = [] // 用于存放结果
const map = {} // 用于存放 list 下的节点
// 1. 遍历 list,将 list 下的所有节点以 id 作为索引存入 map
for (const item of list) {
map[item.id] = { ...item } // 浅拷贝
}
console.log(map)
// 2. 再次遍历,将根节点放入最外层,子节点放入父节点
for (const item of list) {
// 3. 获取节点的 id 和 父 id
const { id, parent_id } = item // 解构
// 4. 如果是根节点,存入 result
if (item.parent_id === root) {
result.push(map[id])
} else {
// 5. 反之,存入到父节点
map[parent_id].children
? map[parent_id].children.push(map[id])
: (map[parent_id].children = [map[id]])
}
}
// 将结果返回
return result
}
console.log(arrayToTree(a, 0))
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
- 实现一个函数来控制发送请求,传值为请求最大数
- 实现一个 todo-list