摘要:分别用广度优先遍历和深度优先遍历展开下面节点示例广度优先遍历输出结果深度优先遍历输出结果关系型数组转换成树形结构对象类似期望输出代码
1.分别用广度优先遍历和深度优先遍历展开下面节点
示例
var tree = {
name: "root",
children: [{
name: "child1",
children: [{
name: "child1_1",
children: []
}, { name: "child1_2", children: [] }]
}, {
name: "child2",
children: [{
name: "child2_1",
children: []
}]
}, {
name: "child3",
children: [{
name: "child2_1",
children: []
}]
}]
};
广度优先遍历:
function wideTraversal(node) {
var nodes = [];
if (node != null) {
var queue = [];
queue.unshift(node);
while (queue.length != 0) {
var item = queue.shift();
nodes.push(item.name);
var children = item.children;
for (var i = 0; i < children.length; i++) {
queue.push(children[i]);
}
}
}
return nodes;
}
console.log(wideTraversal(tree))
输出结果:
[ "root","child1","child2","child3","child1_1","child1_2","child2_1","child2_1" ]
深度优先遍历:
function traverseTree(node) {
var child = node.children,
arr = [];
arr.push(node.name);
if (child) {
child.forEach(function(node) {
arr = arr.concat(traverseTree(node));
});
}
return arr;
}
console.log(traverseTree(tree))
输出结果:
[ "root","child1","child1_1","child1_2","child2","child2_1","child3","child2_1" ]2.关系型数组转换成树形结构对象
类似:
var data = [
{ parentId: 0, id: 1, value: "1" },
{ parentId: 3, id: 2, value: "2" },
{ parentId: 0, id: 3, value: "3" },
{ parentId: 1, id: 4, value: "4" },
{ parentId: 1, id: 5, value: "5" }
]
期望输出:
[
{id:1,value:"1",
children:[{id:4,value:"4",children:[]},
{id:5,value:"5",children:[]}]},
{id:3,value:"3",
children:[id:2,value:"2",children:[]]}]
代码:
var getJsonTree = function(data, parentId) {
var itemArr = [];
for (var i = 0; i < data.length; i++) {
var node = data[i];
//data.splice(i, 1)
if (node.parentId == parentId) {
var newNode = { id: node.id, value: node.value, children: getJsonTree(data, node.id) };
itemArr.push(newNode);
}
}
return itemArr;
}
console.log(getJsonTree(data, 0))
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/109185.html
摘要:示例输入输出示例输入输出第一种方法滑动窗口解法滑动窗口两个边界情况第二种方法位运算解法位运算头条财经部门一面二维数组的回形遍历这是头条财经部门一面的一道题记住遍历过的索引更多前端算法题,参见算法仓库。 1. 百度百家号一面 面完回来搜素,才发现这道题其实是LeetCode540。 540 medium 有序数组中的单一元素 给定一个只包含整数的有序数组,每个元素都会出现两次,唯有一个数...
摘要:求出满足这样要求的路径的数目,并返回。第二道题给定一个数,将其拆分为个平方数的和,求最小的。这道题不能用贪心算法求解。当时,如果用贪心算法,结果就是,返回。假设给出的数字为。第三轮减,得到,将放入队列中。 第一道题:给定一棵二叉树,在二叉树的所有路径中找到路径上结点之和为题目给定值的子路径。路径不一定以根节点为开头,也不一定以叶节点为结尾。并且根据分析路径之间应该可以重叠。求出满足这样...
阅读 1579·2021-10-27 14:14
阅读 3853·2021-09-29 09:34
阅读 2749·2019-08-30 15:44
阅读 1957·2019-08-29 17:13
阅读 2795·2019-08-29 13:07
阅读 1126·2019-08-26 18:26
阅读 3591·2019-08-26 13:44
阅读 3446·2019-08-26 13:37