Leetcoder Day16| 二叉树 part05

news/发布时间2024/5/14 7:09:16

语言:Java/C++ 

513.找树左下角的值

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

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

示例 1:

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

示例 2:

输入: [1,2,3,4,null,5,6,null,null,7]
输出: 7
本题需要满足两个条件:(1) 最后一行的(2) 最左边的值
这里需要明白一个概念是,最左边的值未必就是左孩子,右孩子也是可以的。其实这道题求的是: 深度最大的,从左往右数的第一个叶子节点。因此只要先判断左再判断右即可,所以前中后序都可以。

递归法

首先如何判断是否为最后一行:即深度最大的叶子节点所在即最后一行。
如何找最左边:保证优先左边搜索即可。
  1. 确定递归函数的参数和返回值:参数必须有要遍历的树的根节点,额外使用一个变量来记录深度,不需要有返回值。设置一个全局变量result记录结果。
  2. 确定终止条件:当遇到叶子节点时,判断一下是否为最大深度,用叶子节点来更新最大深度。
  3. 确定单层递归逻辑:在找到最大深度时,递归过程依然需要回溯,因为若当前已经没有节点,需要返回到上一个节点继续找另一条路径进行遍历。
class Solution {int maxDepth=-1;int result;void traversal(TreeNode node, int depth){if(node.left==null && node.right==null){ //叶子节点if(depth>maxDepth) {maxDepth=depth;result=node.val;}}if(node.left!=null){depth++;traversal(node.left,depth);depth--;  //回溯}if(node.right!=null){depth++;traversal(node.right,depth);depth--;  //回溯}return;}public int findBottomLeftValue(TreeNode root) {traversal(root,0);return result;}
}

112. 路径总和  

给你二叉树的根节点  root 和一个表示目标和的整数  targetSum 。判断该树中是否存在  根节点到叶子节点 的路径,这条路径上所有节点值相加等于目标和  targetSum 。如果存在,返回  true ;否则,返回  false

示例 1:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,null,1], targetSum = 22
输出:true
解释:等于目标和的根节点到叶节点路径如上图所示。
因为本题需要遍历到每一条路径进行判断,所以依然需要回溯。本题没有对中节点的处理,所以前中后序都可以。
  1. 递归函数的参数和返回值:本题需要进行判断是否存在满足条件的路径,所以函数类型为bool,参数有根节点和计数器count。主函数里count传入的是目标值减去根节点的值即target-root.val,因此搜索的过程是一个做减法的过程,如果到某一个叶子节点减去以后刚好count=0,则说明存在满足条件的路径。
  2. 终止条件:如果为叶子节点且count==0,则返回true,否则返回false
  3. 单层递归逻辑:即然前中后都可,用前序遍历,先用count减去当前节点的值,判断如果当前回溯的返回值为true,则继续返回true,回溯再把减去的当前值加回去。
class Solution {boolean traversal(TreeNode node, int count){if(node.left==null && node.right==null && count==0) return true;if(node.left==null && node.right==null && count!=0) return false;//左if(node.left!=null){count-=node.left.val;if(traversal(node.left, count)) return true;  //若之前判断有满足条件的,直接truecount+=node.left.val;}if(node.right!=null){count-=node.right.val;if(traversal(node.right, count)) return true;  //若之前判断有满足条件的,直接truecount+=node.right.val;}return false;}public boolean hasPathSum(TreeNode root, int targetSum) {if(root==null) return false;return traversal(root, targetSum-root.val);}
}

113.路径总和ii

和路径总和1不同的是这里让给出所有符合条件的路径,因此返回值发生了变化,不需要有返回值因为要遍历整个树,设置全局变量记录路径和结果。

class Solution {List<List<Integer>> res=new ArrayList<>();List<Integer> path =new LinkedList<>();void traversal(TreeNode node, int count){if(node.left==null && node.right == null && count==0){//res.add(path);res.add(new LinkedList<>(path));return;}if(node.left==null && node.right == null && count!=0) return;if(node.left!=null){path.add(node.left.val);count-=node.left.val;traversal(node.left, count);count+=node.left.val;path.removeLast();}if(node.right!=null){path.add(node.right.val);count-=node.right.val;traversal(node.right, count);count+=node.right.val;path.removeLast();}return;}public List<List<Integer>> pathSum(TreeNode root, int targetSum) {res.clear();path.clear();if(root==null) return res;path.add(root.val);traversal(root, targetSum-root.val);return res;}
}
⚠️:在将path添加到res中时,如果单纯的res.add(path),添加的则是同一个 path的引用,而不是新的路径。当修改 path时,之前添加到 res中的路径也会被修改,导致最终结果中出现重复的路径。因此需要在将 path添加到 res中时创建一个新的 path对象,而不是使用现有的 path对象。

106.从中序与后序遍历序列构造二叉树 

根据一棵树的中序遍历与后序遍历构造二叉树。

注意: 你可以假设树中没有重复的元素。

例如,给出

  • 中序遍历 inorder = [9,3,15,20,7]
  • 后序遍历 postorder = [9,15,7,20,3] 返回如下的二叉树:
按照理论知识,给出中序和后序遍历的时候,首先需要根据后序遍历找出根节点。随后根据根节点将中序一分为二,然后再根据中序分出来的结果切分后序。重复直到切分完最后一个节点。因此需要反复切割,用到递归。
这其中, 为了高效查找根节点元素在中序遍历数组中的下标,我们选择创建哈希表来存储中序序列,即建立一个(元素,下标)键值对的哈希表。
  1. 递归函数的参数和返回值:不需要有返回值,参数则是后序和中序序列
  2. 终止条件:当前序列为空
  3. 单层递归逻辑:后序数组的最后一个元素,根据这个元素的值找到在中序数组的位置root_idx,将中序数组分为,左中序数组和右中序数组。计算左中序数组的个数,以此来确定后序数组中左后序数组的个数。将后序数组分为左后序和右后序。将后序数组中的最后一个元素去掉。
class Solution {Map<Integer, Integer> map;public TreeNode buildTree(int[] inorder, int[] postorder) {return traversal(inorder, 0, inorder.length, postorder, 0, postorder.length);}public TreeNode traversal(int[] inorder, int inB, int inE, int[] postorder, int postB, int postE){if(inB >= inE || postB >= postE) return null;   //返回空树map = new HashMap<>();for (int i=0; i<inorder.length;i++){map.put(inorder[i], i);    //用map来存放中序数组的值和位置,以实现快速查找}int rootIdx=map.get(postorder[postE-1]);   //在中序数组中查找后序的最后一个元素TreeNode root = new TreeNode(inorder[rootIdx]);int lenofLeft=rootIdx-inB;  //左中数组的个数root.left=traversal(inorder, inB, rootIdx, postorder, postB, postB+lenofLeft);   //保持左闭右开root.right=traversal(inorder, rootIdx+1, inE, postorder, postB+lenofLeft, postE-1);return root;}  
}
105.从前序与中序遍历序列构造二叉树

前序和中序的思路和上面的基本一样,就是把取后序数组的最后一个元素换成取前序数组的第一个元素即可。

class Solution {Map<Integer, Integer> map;public TreeNode traversal(int[] preorder,int preB, int preE, int[] inorder, int inB, int inE){if(preE<=preB||inE<=inB) return null;map=new HashMap<>();for(int i=0; i<inorder.length;i++){map.put(inorder[i], i);}int rootIdx=map.get(preorder[preB]);TreeNode root =new TreeNode(inorder[rootIdx]);int lengthOfLeft=rootIdx-inB;root.left=traversal(preorder, preB+1, lengthOfLeft+preB+1, inorder,inB, rootIdx);root.right=traversal(preorder, lengthOfLeft+preB+1, preE, inorder, rootIdx+1, inE);return root;}public TreeNode buildTree(int[] preorder, int[] inorder) {return traversal(preorder, 0, preorder.length, inorder, 0, inorder.length);}
}

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

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

相关文章

optuna,一个好用的Python机器学习自动化超参数优化库

🏷️个人主页:鼠鼠我捏,要死了捏的主页 🏷️付费专栏:Python专栏 🏷️个人学习笔记,若有缺误,欢迎评论区指正 前言 超参数优化是机器学习中的重要问题,它涉及在训练模型时选择最优的超参数组合,以提高模型的性能和泛化能力。Optuna是一个用于自动化超参数优化的…

USB-C 音频转接器工作原理介绍

Type-C音频转接器&#xff1a;引领未来视听新纪元 随着科技浪潮的推进&#xff0c;Type-C接口已逐渐成为电子设备的主流选择。其正反随意插、高速传输和强大功能等独特优势&#xff0c;使得Type-C接口在日常生活中的应用越来越广泛。而Type-C音频转接器&#xff0c;作为连接Ty…

板块一 Servlet编程:第五节 Cookie对象全解 来自【汤米尼克的JAVAEE全套教程专栏】

板块一 Servlet编程&#xff1a;第五节 Cookie对象全解 一、什么是CookieCookie的源码 二、Cookie的具体操作&#xff08;1&#xff09;创建Cookie&#xff08;2&#xff09;获取Cookie&#xff08;3&#xff09;设置Cookie的到期时间&#xff08;4&#xff09;设置Cookie的路径…

文献学习-1-Continuum Robots for Medical Interventions

Chapt 5. 连续体机构分析 5.1 文献学习 5.1.1 Continuum Robots for Medical Interventions Authors: PIERRE E. DUPONT , Fellow IEEE, NABIL SIMAAN , Fellow IEEE, HOWIE CHOSET , Fellow IEEE, AND CALEB RUCKER , Member IEEE 连续体机器人在医学上得到了广泛的应用&a…

Elasticsearch:特定领域的生成式 AI - 预训练、微调和 RAG

作者&#xff1a;来自 Elastic Steve Dodson 有多种策略可以将特定领域的知识添加到大型语言模型 (LLM) 中&#xff0c;并且作为积极研究领域的一部分&#xff0c;正在研究更多方法。 对特定领域数据集进行预训练和微调等方法使 LLMs 能够推理并生成特定领域语言。 然而&#…

Ansible fetch 模块 该模块用于从远程某主机获取(复制)文件到本地

这里写目录标题 参数实例查看返回结果在这里插入图片描述 参数 dest&#xff1a;用来存放文件的目录 src&#xff1a;在远程拉取的文件&#xff0c;并且必须是一个file&#xff0c;不能是**目录* 实例 ansible slave -m fetch -a src/data/hello.txt dest/data/可以看到一个…

手持三防平板丨国产化加固平板丨国产三防平板发展的意义是什么?

随着现代科技的快速发展&#xff0c;平板电脑在我们的生活中扮演着越来越重要的角色。然而&#xff0c;传统的平板电脑只能在普通的环境中使用&#xff0c;而无法在恶劣的环境中使用&#xff0c;例如在高海拔、高温、高湿度、沙漠等环境中&#xff0c;传统平板电脑往往会出现故…

香港Web3:香港虚拟货币 OTC 业务如何合规开展?

撰文&#xff1a;刘红林 文章来源Techub News专栏作者&#xff0c;搜Tehub News下载查看更多Web3资讯。 香港虚拟货币监管两手抓 2024 年 2 月 2 日&#xff0c;香港财经事务及库务局局长许正宇表示&#xff0c;政府认为有需要把虚拟货币场外交易所 (OTC) 纳入监管&#xff0…

PostgreSQL教程(四):高级特性

一、简介 在之前的章节里我们已经涉及了使用SQL在PostgreSQL中存储和访问数据的基础知识。现在我们将要讨论SQL中一些更高级的特性&#xff0c;这些特性有助于简化管理和防止数据丢失或损坏。最后&#xff0c;我们还将介绍一些PostgreSQL扩展。 本章有时将引用教程&#xff0…

Itext生成pdf文件,html转pdf时中文一直显示不出来

之前使用freemark模板渲染ftl页面,转出的pdf中&#xff0c;css2有些样式好像不支持&#xff0c;比较常用的居中样式都没有效果&#xff0c;text-align:center 改造成使用html页面来转pdf&#xff0c;css2的样式可以生效,itext是不支持css3的弹性布局的ITextRenderer pdfRendere…

jmeter 性能测试用 csv

⏩很多人在使用 jmeter 做接口测试、自动化测试和性能测试时&#xff0c;都喜欢用 CSV 数据文件设置功能&#xff0c;来读取准备好的测试数据。虽然这种方法并不是最优方案&#xff0c;在我们的性能测试课程中&#xff0c;讲解了更优的方案&#xff0c;但是&#xff0c;没有上过…

Top 8 免费 iOS 系统恢复软件榜单

智能手机彻底改变了我们在日常生活中执行任务的方式。这种紧凑的设备结合了移动电话和计算功能。这些移动设备具有出色的功能&#xff0c;例如更强大的硬件潜力和广泛的移动操作流程。此外&#xff0c;无线连接和互联网连接的发展使得这种袖珍设备在全球范围内受到需求。iPhone…

CSS学习(三)

目录&#xff1a; 1. CSS引入方式 1.1 三种样式表 1.2 内部样式表&#xff08;嵌入式引入&#xff09; 1.3 行内样式表&#xff08;内联样式表&#xff09; 1.4 外部样式表 1.5 总结 1. CSS引入方式 1.1 三种样式表 1.2 内部样式表&#xff08;嵌入式引入&#xff09; …

Java基础知识

一、标识符规范 标识符必须以字母(汉字)、下划线、美元符号开头&#xff0c;其他部分可以是字母、下划线、美元符号&#xff0c;数字的任意组合。谨记不能以数字开头。java使用unicode字符集&#xff0c;汉字也可以用该字符集表示。因此汉字也可以用作变量名。 关键字不能用作…

差分隐私一些点

无偏估计 E&#xff08;C&#xff09;C &#xff0c; C是常数。 - [ ] 无偏估计&#xff1a;

【无标题】力扣报错:member access within null pointer of type ‘struct ListNode‘

项目场景&#xff1a; 做单链表反转题目&#xff0c;报错&#xff1a;member access within null pointer of type ‘struct ListNode’ 题目链接:LINK 问题描述 我明明在初始化指针时候&#xff0c;已经处理了n2->next情况却依然报错 这个报错提示含义是&#xff1a;大概就…

【JVM】双亲委派机制

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;JVM ⛺️稳中求进&#xff0c;晒太阳 双亲委派机制 在Java中如何使用代码的方式去主动加载一个类呢&#xff1f; 方式1&#xff1a;使用Class.forName方法&#xff0c;使用当前类的类加载…

RK3568平台 内核定时器的使用

一.linux内核定时器 硬件为内核提供了一个系统定时器来计算流逝的时间&#xff08;即基于未来时间点的计时方式&#xff0c;以当前时刻为计时开始的起点&#xff0c;以未来的某一时刻为计时的终点&#xff09;&#xff0c;内核只有在系统定时器的帮助下才能计算和管理时间&…

如何在30天内使用python制作一个卡牌游戏

如何在30天内使用python制作一个卡牌游戏 第1-5天&#xff1a;规划和设计第6-10天&#xff1a;搭建游戏框架第11-20天&#xff1a;核心游戏机制开发第21-25天&#xff1a;游戏界面和用户体验第26-30天&#xff1a;测试和发布附加建议游戏类型游戏规则设计界面设计技术选型第6-…

Android | ArcGIS入门

一、概述 ArcGIS是由Esri开发的地理信息系统&#xff08;GIS&#xff09;软件。它用于制图、空间分析和数据可视化。ArcGIS允许用户以各种格式创建、管理、分析和共享地理信息。它通常用于城市规划、环境管理和应急响应等领域。该软件包括一系列工具&#xff0c;用于创建地图、…
推荐文章