LeetCode404 左叶子之和

前言

题目: 404. 左叶子之和
文档: 代码随想录------左叶子之和
编程语言: C++
解题状态: 成功解答!

思路

注意左叶子节点的定义:节点A的左孩子不为空,且左孩子的左右孩子都为空(说明是叶子节点),那么A节点的左孩子为左叶子节点。

代码

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    void sumLeft(TreeNode* node, int& sum) {
        if (node == NULL) return;
        TreeNode* leftNode = node -> left;
        TreeNode* rightNode = node -> right;
        if (leftNode) {
            if (leftNode -> left == NULL && leftNode -> right == NULL) {
                sum += leftNode -> val;
            } else {
                sumLeft(leftNode, sum);
            }
        }

        if (rightNode) {
            sumLeft(rightNode, sum);
        }
    }
    int sumOfLeftLeaves(TreeNode* root) {
        int sum = 0;
        sumLeft(root, sum);
        return sum;
    }
};
相关推荐
奋进的小暄13 分钟前
贪心算法(15)(java)用最小的箭引爆气球
算法·贪心算法
Scc_hy25 分钟前
强化学习_Paper_1988_Learning to predict by the methods of temporal differences
人工智能·深度学习·算法
巷北夜未央26 分钟前
Python每日一题(14)
开发语言·python·算法
javaisC28 分钟前
c语言数据结构--------拓扑排序和逆拓扑排序(Kahn算法和DFS算法实现)
c语言·算法·深度优先
爱爬山的老虎29 分钟前
【面试经典150题】LeetCode121·买卖股票最佳时机
数据结构·算法·leetcode·面试·职场和发展
SWHL29 分钟前
rapidocr 2.x系列正式发布
算法
阳光_你好44 分钟前
请详细说明opencv/c++对图片缩放
c++·opencv·计算机视觉
杰克逊的黑豹1 小时前
不再迷茫:Rust, Zig, Go 和 C
c++·rust·go
雾月551 小时前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
想跑步的小弱鸡1 小时前
Leetcode hot 100(day 4)
算法·leetcode·职场和发展