二叉树|力扣404.左叶子之和,广度优先和深度优先遍历

404.左叶子之和

力扣题目链接(opens new window)

计算给定二叉树的所有左叶子之和。

示例:

404.左叶子之和1

 

思路:

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

因为题目中其实没有说清楚左叶子究竟是什么节点,那么我来给出左叶子的明确定义:节点A的左孩子不为空,且左孩子的左右孩子都为空(说明是叶子节点),那么A节点的左孩子为左叶子节点

大家思考一下如下图中二叉树,左叶子之和究竟是多少?

404.左叶子之和

 其实是0,因为这棵树根本没有左叶子!

但看这个图的左叶子之和是多少?

图二

相信通过这两个图,大家对最左叶子的定义有明确理解了。

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

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

//深度优先遍历

/**
 * 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:
    int sumOfLeftLeaves(TreeNode* root) {
        
       if(root==nullptr)return 0;
       if(root->left==nullptr&& root->right==nullptr)return 0;//终止条件

       int leftvalue=sumOfLeftLeaves(root->left);//遍历左子树
       if(root->left&&root->left->left==nullptr&&root->left->right==nullptr){
            leftvalue=root->left->val;//中
       }
       int rightvalue=sumOfLeftLeaves(root->right);//遍历右子树
       int sum =leftvalue+rightvalue;
        return sum;

    }
};

//深度优先遍历法

/**
 * 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:
    int sumOfLeftLeaves(TreeNode* root) {
        queue<TreeNode*>que;
        if(root==nullptr)return 0;
        int leftNodeSum=0;
        que.push(root);
        while(!que.empty()){
            int size=que.size();
            for(int i=0;i<size;i++){
                TreeNode* node =que.front();
                que.pop();
                if(node->left&&node->left->left==nullptr&&node->left->right==nullptr){
                   leftNodeSum +=node->left->val;
                }
                if(node->left) que.push(node->left);
                if(node->right) que.push(node->right);
            }
        }
        return leftNodeSum;

    }
};

 

参考:代码随想录 

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-28 18:22:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-28 18:22:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-28 18:22:02       82 阅读
  4. Python语言-面向对象

    2024-03-28 18:22:02       91 阅读

热门阅读

  1. 现在做视频号小店晚吗?平台发展趋势如何?

    2024-03-28 18:22:02       42 阅读
  2. linux 命令行下的计算器

    2024-03-28 18:22:02       56 阅读
  3. requests模块处理cookie

    2024-03-28 18:22:02       37 阅读
  4. 区块链备案,为信息安全加把锁

    2024-03-28 18:22:02       38 阅读
  5. 观察者模式和发布-订阅模式有什么异同

    2024-03-28 18:22:02       38 阅读
  6. C语言中实现atoi函数实现

    2024-03-28 18:22:02       36 阅读
  7. 力扣由浅至深 每日一题.16 合并两个有序数组

    2024-03-28 18:22:02       47 阅读
  8. 深度学习系列63:tts和智能语音助手

    2024-03-28 18:22:02       46 阅读