前言
数组转树是一种常见的数据结构转换操作,目的是将平面的数组数据组织成具有层级关系的树形结构。这种转换在许多实际应用场景中非常有用。很多现实世界的数据本质上是层级结构的,比如文件系统、组织架构、分类目录等。数组通常是扁平化的,而树形结构可以更直观地反映这些层级关系。
递归实现数组转数
js
let list = [
{ "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": "广东省" }
]
const arrToTree(list,parentId){
let len=list.length;
function loop(parentId){
let res=[];
for(let i=0;i<len;i++){
let item=list[i];
if(item.parent_id===parentId){
item.children=loop(item.id)
res.push(item)
}
}
return res
}
return loop(parentId)
}
let result= arrToTree(list,0)
console.log(result);
哈希map
js
function fn(list){
let obj={}
let res=[]
for(let item of list){
obj[item.id]=item
}
for(let item of list){
if(obj[item.parent_id]){
(obj[item.parent_id].children||(obj[item.parent_id].children=[])).push(item)
}else{
res.push(item)
}
}
return res
}
console.log(fn(list))