404. 左叶子之和

404. 左叶子之和

原题

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    int sum = 0;
    public int sumOfLeftLeaves(TreeNode root) {
        //第二个参数代表当前结点是左节点(1),还是右节点(0),一开始传0,让头结点不参与运算
        dfs(root,0);
        return sum;
    }

    public void dfs(TreeNode node,int i){
        if(node==null){
            return;
        }
        //为叶子结点
        if(node.left==null&&node.right==null){
            //为左叶子节点
            if(i==1){
                sum += node.val;
            }
        }
        //左子树递归
        dfs(node.left,1);
        //右子树递归
        dfs(node.right,0);
    }
}   
相关推荐
Infedium7 分钟前
优数:助力更高效的边缘计算
算法·业界资讯
student.J27 分钟前
傅里叶变换
python·算法·傅里叶
五味香33 分钟前
C++学习,动态内存
java·c语言·开发语言·jvm·c++·学习·算法
Beauty.56839 分钟前
P1328 [NOIP2014 提高组] 生活大爆炸版石头剪刀布
数据结构·c++·算法
Aurora200540 分钟前
蓝桥杯2024省C
c语言·算法·蓝桥杯
爱棋笑谦41 分钟前
二叉树计算
java·开发语言·数据结构·算法·华为od·面试
小鱼在乎1 小时前
动态规划---最长回文子序列
算法·动态规划
xiaobai12 31 小时前
二叉树的遍历【C++】
开发语言·c++·算法
吱吱鼠叔2 小时前
MATLAB数学规划:2.线性规划
算法·机器学习·matlab
声学黑洞仿真工作室2 小时前
Matlab Delany-Bazley和Miki模型预测多孔材料吸声性能
开发语言·人工智能·算法·matlab·微信公众平台