求根到叶子节点数字之和
求根到叶子节点数字之和
给定一个二叉树,它的每个结点都存放一个 0-9 的数字,每条从根到叶子节点的路径都代表一个数字。
例如,从根到叶子节点路径 1->2->3 代表数字 123。
计算从根到叶子节点生成的所有数字之和。
说明: 叶子节点是指没有子节点的节点。
示例 1:
输入: [1,2,3]
1
/ \
2 3
输出: 25
解释:
从根到叶子节点路径 1->2 代表数字 12.
从根到叶子节点路径 1->3 代表数字 13.
因此,数字总和 = 12 + 13 = 25.
示例 2:
输入: [4,9,0,5,1]
4
/ \
9 0
/ \
5 1
输出: 1026
解释:
从根到叶子节点路径 4->9->5 代表数字 495.
从根到叶子节点路径 4->9->1 代表数字 491.
从根到叶子节点路径 4->0 代表数字 40.
因此,数字总和 = 495 + 491 + 40 = 1026.
答案
深度优先搜索解题法:
从根节点开始,遍历每个节点,如果遇到叶子节点,则将叶子节点对应的数字加到数字之和。如果当前节点不是叶子节点,则计算其子节点对应的数字,然后对子节点递归遍历。
/**
* @param {TreeNode} root
* @return {number}
*/
var sumNumbers = function (root) {
const dfs = (root, prevSum) => {
if (root === null) return 0;
let sum = prevSum * 10 + root.val; // 这里假设父节点 为 0 , 得到节点上的对应的数字
if (root.left === null && root.right === null) {
return sum;
}
let res = dfs(root.left, sum) + dfs(root.right, sum);
return res;
};
return dfs(root, 0);
};
let root = {
val: 4,
left: {
val: 9,
left: {
val: 5,
left: null,
right: null,
},
right: {
val: 1,
left: null,
right: null,
},
},
right: {
val: 0,
left: null,
right: null,
},
};
const num = sumNumbers(root);
广度优先搜索解题法:
使用广度优先搜索,需要维护两个队列,分别存储节点和节点对应的数字。
初始时,将根节点和根节点的值分别加入两个队列。每次从两个队列分别取出一个节点和一个数字,进行如下操作:
如果当前节点是叶子节点,则将该节点对应的数字加到数字之和;
如果当前节点不是叶子节点,则获得当前节点的非空子节点,并根据当前节点对应的数字和子节点的值计算子节点对应的数字,然后将子节点和子节点对应的数字分别加入两个队列。
搜索结束后,即可得到所有叶子节点对应的数字之和。
/**
* @param {TreeNode} root
* @return {number}
*/
var sumNumbers = function (root) {
if (root === null) return 0;
let sum = 0;
const nodeQueue = [];
const numQueue = [];
nodeQueue.push(root);
numQueue.push(root.val);
while (nodeQueue.length) {
const node = nodeQueue.shift(); // shift 返回数组中第一个元素
const num = numQueue.shift();
const left = node.left;
const right = node.right;
if (left === null && right === null) {
sum += num;
} else {
if (left !== null) {
nodeQueue.push(left);
numQueue.push(num * 10 + left.val);
}
if (right !== null) {
nodeQueue.push(right);
numQueue.push(num * 10 + right.val);
}
}
}
return sum;
};
let root = {
val: 4,
left: {
val: 9,
left: {
val: 5,
left: null,
right: null,
},
right: {
val: 1,
left: null,
right: null,
},
},
right: {
val: 0,
left: null,
right: null,
},
};
const num = sumNumbers(root);
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!