404. 左叶子之和

原题链接:404. 左叶子之和

思路:

首先要注意是判断左叶子,不是二叉树左侧节点,所以不要上来想着层序遍历。

节点A的左孩子不为空,且左孩子的左右孩子都为空(说明是叶子节点),那么A节点的左孩子为左叶子节点

判断当前节点是不是左叶子是无法判断的,必须要通过节点的父节点来判断其左孩子是不是左叶子

该节点的左节点不为空,该节点的左节点的左节点为空,该节点的左节点的右节点为空,则找到了一个左叶子

当遇到左叶子节点的时候,记录数值,然后通过递归求取左子树左叶子之和,和 右子树左叶子之和,相加便是整个树的左叶子之和

全代码:

cpp 复制代码
class Solution {
public:
    int sumOfLeftLeaves(TreeNode* root) {
        
        if(root == NULL) return 0;//空树
    
        if(root ->left == NULL && root ->right == NULL) return 0;//叶子节点

        int leftValue = sumOfLeftLeaves(root ->left);//传入左子树
        if(root ->left != NULL && root ->left->left == NULL && root ->left ->right == NULL)
        { // 左子树就是一个左叶子的情况
            leftValue = root ->left ->val;//
        }
        int rightValue = sumOfLeftLeaves(root ->right);

        //把左子树和右子树的左叶子结点的值相加,得到最终值
        int sum = leftValue + rightValue;
        return sum;
    }

};
相关推荐
AuroraWanderll3 分钟前
类和对象(六)--友元、内部类与再次理解类和对象
c语言·数据结构·c++·算法·stl
leaves falling6 分钟前
c语言-给定两个数,求这两个数的最大公约数
数据结构·算法
想做后端的小C7 分钟前
数据结构:线性表原地逆置
数据结构·考研
jikiecui7 分钟前
信奥崔老师:三目运算 (Ternary Operator)
数据结构·c++·算法
无限进步_8 分钟前
【C语言&数据结构】另一棵树的子树:递归思维的双重奏
c语言·开发语言·数据结构·c++·算法·github·visual studio
志摩凛17 分钟前
Element UI 长表单校验失败后自动展开折叠面板并滚动定位
数据结构·vue.js
一起努力啊~25 分钟前
算法刷题--链表
数据结构·算法·链表
不被AI替代的BOT38 分钟前
【实战】企业级物联网架构-元数据与物模型
数据结构·架构
郝学胜-神的一滴1 小时前
《机器学习》经典教材全景解读:周志华教授匠心之作的技术深探
数据结构·人工智能·python·程序人生·机器学习·sklearn
平哥努力学习ing1 小时前
《数据结构》-第八章 排序
数据结构·算法·排序算法