当前位置: 首页 > news >正文

LeetCode404 左叶子之和

前言

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

思路

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

代码

/*** 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;}
};
http://www.lryc.cn/news/424438.html

相关文章:

  • nodejs操作redis的工具类
  • 关于wsl2与win11互联互通的问题
  • C++ 类型转换
  • 2024挖漏洞给报酬的网站汇总,兼职副业3天收益2k
  • 0到1学习Google广告(2):掌握展示位置及排名规则丨出海笔记
  • MySQL数据库读超时/SELECT查询超时 杂记
  • docker数据卷:
  • 【linux】linux中如何通过systemctl来创建和管理服务
  • WPF-实现多语言的静态(需重启)与动态切换(不用重启)
  • UE5学习笔记12-为角色添加蹲下的动作
  • 【笔记】Android 多用户模式和用户类型
  • SQL基础——MySQL的索引
  • 【开发语言】面向对象和面向过程开发思路的区别
  • 谷歌账号登录的时候提示被停用,原因是什么,账号还有救吗?该如何处理?
  • 数据库复习笔记
  • 学习STM32(6)-- STM32单片机ADCDAC的应用
  • 学习记录第二十五天
  • C语言:字符串函数strcmp
  • 【数据分析---偏企业】 Excel操作
  • Ajax-01.原生方式
  • OpenAI GPT-2 model use with TensorFlow JS
  • JVM-运行数据区(堆、栈、元空间)
  • 超详细!!! LVS(Linux virual server)负载均衡知识及其NAT模式、DR模式、火墙标记实验
  • 信息学奥赛一本通1259:【例9.3】求最长不下降序列
  • 星露谷模组开发教程#3 事件
  • C语言程序设计(初识C语言后部分)
  • 驱动基础开发
  • 从苹果AppStore看AI开发者生态
  • 【Python学习-UI界面】PyQt5 小部件1-Label
  • 【Linux详解】进度条实现 Linux下git 的远程上传