题目:
计算给定二叉树的所有左叶子之和。
示例:
3
/ \
9 20
/ \
15 7在这个二叉树中,有两个左叶子,分别是 9 和 15,所以返回 24
思路:
对整棵树进行遍历
如果左子节点是叶子节点,则累加求和
代码实现:
/**
* Definition for a binary tree node.
* function TreeNode(val) {
* this.val = val;
* this.left = this.right = null;
* }
*/
/**
* @param {TreeNode} root
* @return {number}
*/
var sumOfLeftLeaves = function (root) {
if (root == null) return 0;
return countLeft(root);
};
var countLeft = function (root) {
let sum = 0;
if (root.left != null) {
sum += isLeafNode(root.left) ? root.left.val : countLeft(root.left);
}
if (root.right != null && !isLeafNode(root.right)) {
sum += countLeft(root.right);
}
return sum;
}
var isLeafNode = function (node) {
return node.left == null && node.right == null;
}