Day43 代码随想录打卡|二叉树篇---左叶子之和

题目(leecode T404):

给定二叉树的根节点 root ,返回所有左叶子之和。

方法:

迭代法:计算所有的左叶子节点,那我们就必然要找到所有的左叶子节点。那么怎么找呢?如何针对cur->left == NULL&&cur->right ==NULL的话只能判断当前节点是叶子节点,而无法判断出具体是左还是右。因此我们需要从左叶子节点的父节点进行判断,即cur->left != NULL&&cur->left == NULL&&cur->right ==NULL,这样的节点的左孩子结点就是一个左叶子节点。我们这样就确定好了找到左叶子节点的判断逻辑。下面分析迭代的三部曲。

1:确定传入的参数和返回值,传入的参数就是要处理的树节点,返回值是左叶子节点的数值之和,因此需要为int,进行迭代累加得到的就是做叶子节点的和。

2:确定终止条件,当我们遍历到了空节点时,肯定是没有左孩子结点了,就需要终止。

3:确定单层的处理逻辑,当我们找到了左叶子节点时,就记录左叶子节点的值,同时递归根节点的左右子树,最后将两值相加即可得到该树的左叶子节点之和。

题解:

class Solution {
public:
    int sumOfLeftLeaves(TreeNode* root) {
        if(root == 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;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/681615.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

电路分析答疑 1

三要素法求解的时候, 电容先求U,再利用求导求I 电感先求I,再利用求导求U 若I的头上没有点点,那就是求有效值 叠加定理,不要忘记 若电流值或者电压值已经给出来了,那就说明这一定是直流电。 在画画圈的时候…

【Qt】Qt Style Sheets (QSS) 指南:打造个性化用户界面

文章目录 前言:1. QSS 选择器2. 子控件选择器(Sub-Controls)2.1. 示例:给 QComboBox 给下拉按钮加上图标2.2. 示例:修改进度条颜色 3. 伪类选择器3.1. 代码示例: 设置按钮的伪类样式.3.2. 代码示例: 使用事件方式实现同…

超级羊毛!Splashtop SOS 远程软件免费用!

​作为新时代的 IT 青年,您是否经常被亲朋好友、同事、客户们请求帮助解决各种电脑、手机问题?您是否需要一个免费好用的远程支持软件? 机会来了,我们现在免费送您一年专业商业远程支持软件——Splashtop SOS,价值990…

计算病理学的视觉语言基础模型| 文献速递-视觉通用模型与疾病诊断

Title 题目 A visual-language foundation model for computational pathology 计算病理学的视觉语言基础模型 01 文献速递介绍 数字病理学的快速普及和深度学习的进步使得可以开发出针对各种疾病和患者群体的各种病理学任务的强大模型。然而,由于医学领域标签…

windows下 Qt 操作xlsx 和 csv

需求: 工作中遇到一个需求,有两张表格,一个xlsx表,一个csv表格,格式如下: 以csv表格中船台标识为基础,读取xlsx中的数据,如果存在该MMSI则把船名写道csv中对应船名的后面,不存在的话,则添加进csv中,合并两个表格。由于表格数据非常多,有十几万个,所以只能通过程序…

ClickHouse内幕(1)数据存储与过滤机制

本文主要讲述ClickHouse中的数据存储结构,包括文件组织结构和索引结构,以及建立在其基础上的数据过滤机制,从Part裁剪到Mark裁剪,最后到基于SIMD的行过滤机制。 数据过滤机制实质上是构建在数据存储格式之上的算法,所…

GNN与Transformer创新结合!模型性能起飞!

前言 近年来,图神经网络(GNN)和Transformer模型分别凭借其独到的优势,在处理复杂数据结构和识别序列间的相互依赖性方面取得了突破性进展,这些优势使得GNN和Transformer的结合成为图表示学习领域的一个有前景的研究方…

微信小程序实现图生图(AI动漫特效)效果代码(触站API)

1.效果 触站AI图生图 2.本次用的是触站平台的API,我申请的适用积分,有水印(博主没钱)。如果需要没有水印的可以去买他们的资源包 3.首先我们需要去触站官网平台注册/登录账号(已注册可跳过该步骤) 4.开通API权限 我们可以在主页看到自己免费获取的500积分,用于接口调用…

Echarts 中type是value的X轴在设置了interval间隔后没有展示

文章目录 问题分析问题 Echarts中type是value的X轴在设置了interval间隔后没有展示 分析 之前代码是这样写的:axisLabel 属性中设置了 interval ,但未起作用,原因如下 在 ECharts 中,interval 属性是用于类目型(category)轴的刻度间隔设置,并不适用于数值型(value)…

2024会声会影激活码免费注册码大揭秘!

在当今数字化时代,视频编辑已经成为了许多人日常生活和工作中不可或缺的一部分。无论是制作短视频、Vlog还是专业影视剪辑,一款优秀的视频编辑软件都能让我们事半功倍。而市面上众多的视频编辑软件中,会声会影无疑是备受瞩目的一款。本文将为…

如何将华为Ascend手机的短信和联系人安全传输到电脑

华为Ascend系列手机以其流畅的使用体验、光滑的触感以及轻巧的设计赢得了市场的青睐。不仅如此,Ascend系列手机还以亲民的价格和出色的用户体验,搭载了众多先进功能,如Ascend P6的4.7英寸大屏、海思四核处理器、2GB RAM和800万像素摄像头等。…

3 - 大的国家(高频 SQL 50 题基础版)

3.大的国家 -- 查询属性:国家名称、人口和面积 select name,population,area fromWorld where area>3000000 OR population>25000000;

【启明智显分享】Model3A 7寸彩屏应用于智能中控屏解决方案

比尔盖茨曾在出版的《未来之路》中预言:“在不远的未来,没有智能家居系统的住宅会像不能上网的住宅一样不合潮流”。随着5G时代的到来,国内十几万家企业竞逐智能家居的产业赛道。智能家居的风口已然到来,智能家居产品也不断进行升…

图片如何修改尺寸?四种好用的修改图片尺寸方法!

图片如何修改尺寸?图片是一种常见的文件类型,它存在于什么生活的方方面面,虽然图片很好用,但是大家日常也要注意图片的尺寸,如果图片尺寸不对是会带来很多问题的,下面小编就举例说明几个问题,首…

Android Studio 中文汉化教程

1. 中文语言包 一般jetbrains系列软件都可以使用“中文语言包”进行汉化,语言包如下图所示: 然而,Android Studio的Marketplace并没有类似的中文语言包(如下图),经过查阅相关资料发现需要去jetbrains的插件…

【C语言】结构体(及位段)

你好!感谢支持孔乙己的新作,本文就结构体与大家分析我的思路。 希望能大佬们多多纠正及支持 !!! 个人主页:爱摸鱼的孔乙己-CSDN博客 欢迎 互粉哦🙈🙈! 目录 1. 声明结构…

查看 samba 文件共享服务器地址的具体 IP

问题背景 在某个局域网中,已知 samba 文件共享服务器的地址如 \\samba_share在该局域网的子网中,由于 dns 服务器缺失,无法通过地址 \\samba_share 直接访问该服务器 解决方法 使用 ping 命令查看某个地址的 ip : ping [addre…

【Java面试】十四、LinkedList相关

文章目录 1、单向链表1.1 结构1.2 查询的时间复杂度1.3 插入删除的时间复杂度 2、双向链表2.1 时间复杂度 3、ArrayList和LinkedList的区别是什么 1、单向链表 1.1 结构 存储空间上,非连续链表的每个元素称结点Node每个结点包括两块:存储数据的数据域d…

C++11标准-详解

目录 1、列表初始化 2、隐式类型转换 1)概念理解 2)举例增进理解 3)隐式与显式区别? a、直接初始化 vs 拷贝初始化 b、构造函数调用 c、语义上的差异 d、性能差异 4)explicit 关键字 5)多参数的隐…

Python 组合序号

import pandas as pd # 创建一个示例数据框 data { group: [A, A, A, B, B, C, C, C, C], value: [3, 1, 2, 5, 4, 6, 9, 7, 8] } df pd.DataFrame(data) # 先按group分组,再按value列升序排序 df_sorted_asc df.sort_values(by[group, value]) # 使…