力扣404 左叶子之和 Java版本

文章讲述了如何使用后序遍历的方法计算给定二叉树中所有左叶子节点的和,通过递归实现,提供了一个名为Solution的类中的sumOfLeftLeaves函数作为解决方案。
摘要由CSDN通过智能技术生成


题目描述

给定二叉树的根节点 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;
    }
}
  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值