1月11日代码随想录513找树左下角的值

513.找树左下角的值

给定一个二叉树的 根节点 root,请找出该二叉树的 最底层 最左边 节点的值。

假设二叉树中至少有一个节点。

示例 1:

输入: root = [2,1,3]
输出: 1

示例 2:

输入: [1,2,3,4,null,5,6,null,null,7]
输出: 7

提示:

  • 二叉树的节点个数的范围是 [1,104]
  • -231 <= Node.val <= 231 - 1 

思路

广度优先搜索

找到最后一层的最左边的节点,这个题目很直观地能够想到层序遍历一层一层往下走然后到最后一层找最左侧的节点,但是有一个问题,如果按照之前写的层序遍历,判断遍历结束的条件是队列为空,但是在所有节点遍历完之前无法判断当前层是否为最后一层,所以每次都要把当前层第一个存入队列的数记录,这可以是一种方法,但是我们可以换一种思路,就是将遍历的顺序做一个小调换,每次先找右节点再找左节点,这样的话遍历的最后一个节点必定是最后一层最左侧的节点,我们只需要在层序遍历中加一个队列判空就可以存储答案的值,非常巧妙。

class Solution {public int findBottomLeftValue(TreeNode root) {if(root==null){return 0;}Queue<TreeNode> queue=new LinkedList<TreeNode>();queue.offer(root);int ans=0;while(!queue.isEmpty()){int length=queue.size();for(int i=0;i<length;i++){TreeNode node=queue.poll();if(node.right!=null){queue.offer(node.right);}if (node.left != null) {queue.offer(node.left);}if(queue.isEmpty()){ans=node.val;}}}return ans;}
}

深度优先搜索

至于深搜法在这道题目里我认为不是很直观,使用height记录当前遍历到的节点的高度,curVal记录在curHeight深度最左侧节点的值,在搜索时先搜索左子树在搜索右子树,因为先遍历左子树再遍历右子树,所以必定是当前层最左侧的值先被遍历到。

class Solution {int curVal=0;int curHeight=0;public int findBottomLeftValue(TreeNode root) {int curHeight=0;dfs(root,curHeight);return curVal;}public void dfs(TreeNode root,int height){if(root==null){return;}height++;dfs(root.left,height);dfs(root.right,height);if(height>curHeight){curHeight=height;curVal=root.val;}}
}

总结

这道题目还是适合广搜法的思想一点,深搜的递归思想需要一定的熟练度。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java 干货教程】Java实现分页的几种方式详解

一、前言 无论是自我学习中&#xff0c;还是在工作中&#xff0c;固然会遇到与前端搭配实现分页的功能&#xff0c;发现有几种方式&#xff0c;特此记录一下。 二、实现方式 2.1、分页功能直接交给前端实现 这种情况也是有的&#xff0c;(根据业务场景且仅仅只能用于数据量…

【BIAI】Lecture 7 - EEG data analysis

EEG data analysis 专业术语 EEG 脑电图 excitatory postsynaptic potential(EPSP)兴奋性突触后电位 inhibitory postsynaptic potential(IPSP) 抑制性突触后电位 action potential 动作电位 dipoles 偶极子 Pyramidal neurons 椎体细胞 Axon 轴突 Dendrite 树突 Synapse 突触…

C++的虚基类

前言 本文介绍C的虚基类 先看一个问题 先看一段代码 #include <iostream> class A { public:int a 1; };class B1:public A { public:int b1 2; };class B2 :public A { public:int b2 3; };class C1:public B1,public B2 { public:int c1 4; };int main(int arg…

HarmonyOS应用开发学习笔记 arkTS自定义弹窗(CustomDialog)简单使用 arkTS弹出框回调、监听

HarmonyOS应用开发学习笔记 arkTS自定义弹窗&#xff08;CustomDialog&#xff09;简单使用 1、CustomDialog装饰器用于装饰自定义弹框 1、定义弹出框 CustomDialog CustomDialog export struct CustomDialogExample {controller: CustomDialogControllerbuild() {Column() {…

景联文科技:以高质量数据赋能文生图大模型

1月5日&#xff0c;在智求共赢・中国AIGC产业应用峰会暨无界AI生态合作伙伴大会上&#xff0c;中国AIGC产业联盟联合无界AI发布了《中国AIGC文生图产业白皮书2023》&#xff0c;从AIGC文生图发展历程、主流工具、产业实践以及规模预测等多个维度&#xff0c;全面揭示了中国AIGC…

【案例】HOOPS平台帮助Proplanner为客户解决数十年的数据管理难题

行业&#xff1a;制造业公司&#xff1a;Proplanner软件&#xff1a;Assembly Planner软件开发工具包&#xff1a;HOOPS Native Platform挑战&#xff1a; 为生产复杂组件的公司引入行业领先产品的新功能。帮助客户轻松导入可视化CAD模型&#xff0c;同时提取底层数据。在工艺…

开发知识点-RabbitMQ

RabbitMQ 下载与介绍权限了解消息状态rabbitmqctl命令与操作配置常见错误常见问题日志 poc-yaml-rabbitmq-default-password 下载与介绍 RabbitMQ是一个使用Erlang语言开发 开源的消息中间件项目&#xff08;Message Broker&#xff09;&#xff0c; 采用Mozilla Public Licen…

高效底座模型LLaMA

论文标题&#xff1a;LLaMA: Open and Efficient Foundation Language Models 论文链接&#xff1a;https://arxiv.org/pdf/2302.13971.pdf 论文来源&#xff1a;Meta AI 1 概述 大型语言模型&#xff08;Large Languages Models&#xff0c;LLMs&#xff09;通过大规模文本数…

Leetcode 416 分割等和子集

题意理解&#xff1a; 给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集&#xff0c;使得两个子集的元素和相等。 即将数组的元素分成两组&#xff0c;每组数值sum(nums)/2 若能分成这样的两组&#xff0c;则返回true,否则返回false 本质上…

EasyExcel简单实例

EasyExcel简单实例 准备工作场景一&#xff1a;读取 Student 表需求1&#xff1a;简单读取需求2&#xff1a;读取到异常信息时不中断需求3&#xff1a;读取所有的sheet工作表需求4&#xff1a;读取指定的sheet工作表需求5&#xff1a;从指定的行开始读取 场景二&#xff1a;写入…

【方差分析原理简介】

文章目录 方差分析&#xff08;Analysis of Variance&#xff0c;简称ANOVA&#xff09;1 方差分析流程2 借助sklean进行基于方差分析的特征筛选3 总结 方差分析&#xff08;Analysis of Variance&#xff0c;简称ANOVA&#xff09; 卡方检验更多的会考虑在衡量两个离散变量是…

大数据系列之:腾讯云服务器性能和价格比较

大数据系列之&#xff1a;腾讯云服务器性能和价格比较 一、磁盘性能和价格比较二、高性能云硬盘三、ssd云硬盘四、极速型ssd云硬盘五、增强型ssd云硬盘六、查看腾讯云服务器价格 一、磁盘性能和价格比较 磁盘名称高性能ssd云硬盘极速型ssd云硬盘增强型ssd云硬盘规格500g 5800 …