当前位置:   article > 正文

力扣404 左叶子之和 Java版本

力扣404 左叶子之和 Java版本


题目描述

给定二叉树的根节点 root ,返回所有左叶子之和。

示例 1:
在这里插入图片描述

输入: root = [3,9,20,null,null,15,7]
输出: 24
解释: 在这个二叉树中,有两个左叶子,分别是 9 和 15,所以返回 24
示例 2:

输入: root = [1]
输出: 0

提示:

节点数在 [1, 1000] 范围内
-1000 <= Node.val <= 1000

解题思路

这个问题使用后序遍历和层序遍历都是可以的,只需要在遍历的过程中判断一下当前节点的左孩子节点是否是左叶子节点。如果是的话就加起来。
下面附上后序遍历的递归解法

代码

class Solution {
    public int sumOfLeftLeaves(TreeNode root) {
        //使用前序遍历的递归方法,每次递归到一个节点的时候就判断是否是左孩子
        //递归出口
        if (root == null) {
            return 0;
        }

        int leftNum = 0;//表示左子树中左叶子节点之和
        int rightNum = 0;//表示右子树中左叶子节点之和
        //如果左子树不为空,就判断一下这个节点是否会是左叶子
        if (root.left!=null){
            //如果是左叶子就给leftNum加上这个左叶子的val
            if (root.left.left == null && root.left.right == null) {
                leftNum = sumOfLeftLeaves(root.left) + root.left.val;
            } else {
                leftNum = sumOfLeftLeaves(root.left);
            }
        }else {//左子树为空的话也不需要单独处理,直接往下递归就行,如果为空的话自然下一步就返回0了
            leftNum = sumOfLeftLeaves(root.left);
        }

        //往右子树那一侧递归统计
        rightNum = sumOfLeftLeaves(root.right);
        //返回左右子树中左叶子节点的总和
        return leftNum + rightNum;
    }
}
  • 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
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/206038
推荐阅读
相关标签
  

闽ICP备14008679号