代码随想录算法训练营第20天 |654.最大二叉树、 617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树

本文主要是介绍代码随想录算法训练营第20天 |654.最大二叉树、 617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码随想录算法训练营第20天 |654.最大二叉树、 617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树

  • 自己看到题目的第一想法
  • 看完代码随想录之后的想法
  • 自己实现过程中遇到哪些困难

链接: 654.最大二叉树
链接: 617.合并二叉树
链接: 700.二叉搜索树中的搜索
链接: 98.验证二叉搜索树

自己看到题目的第一想法

654.最大二叉树:明确了是递归法,知道应该使用三部曲,首先确定递归函数的参数和返回类型,构建二叉树返回类型是void,参数为数组;终止条件应该是数组使用完成;递归函数内的逻辑是前序遍历。
700.二叉搜索树中的搜索:递归,前序遍历

看完代码随想录之后的想法

654.最大二叉树:首先整体思路是递归,三部曲,递归函数输入参数是数组,返回值应当是根节点,而不是空,这点我自己第一想法是错误的,终止条件应该是数组的长度为1,因为数组长度为1说明此时已经是在叶子节点了,递归函数内部逻辑是前序遍历,先根据输入数组的最大值构造根节点,因为是数组,根据数组的特点可以根据最大值索引下标划分成左右子数组从而分别对左子树和右子树进行构造。另外可以回顾一下昨天的题目。

class Solution {public TreeNode constructMaximumBinaryTree(int[] nums) {return Construct(nums,0,nums.length-1);}public TreeNode Construct(int[] nums,int leftIndex,int rightIndex){if(leftIndex>rightIndex){return null;}//求数组的最大值索引下标int maxIndex =leftIndex;for(int i=leftIndex+1;i<=rightIndex;i++){if(nums[maxIndex]<nums[i]){maxIndex=i;}}//构建中间节点TreeNode root = new TreeNode(nums[maxIndex]);//左root.left = Construct(nums,leftIndex,maxIndex-1);root.right=Construct(nums,maxIndex+1,rightIndex);return root;}
}

617.合并二叉树:同时处理两个二叉树,在一个二叉树上操作,前序遍历。
700.二叉搜索树中的搜索:自己忽略了二叉搜索树是个有序树。
98.验证二叉搜索树:自己写代码碰到了陷阱,题目要求的是所有左子树的节点而不是只比较该节点的左节点。
自己错误的写法增加了判断左右节点不为空的情况之后还是会无法通过全部测试样例:
这样写会因为下面的情况而错误
在这里插入图片描述这道题有思路是简单的,但是难点在于能否写出通过全部样例的代码。通常写的代码是递归每一个节点的左右子树的大小关系,而并不能表明左右子树的所有都是满足大小关系的。看了题解之后觉得,利用一步步更新的边界值来限定节点会规范这个问题。
这道题和700题有思想相近的地方,都是通过更新限定来递归。

自己实现过程中遇到哪些困难

654.最大二叉树:这道题有两种想法,第一种是更耗时耗空间的方法,也就是我上面写的看完随想录之后的想法,它耗时的原因是每次递归都重新创建数组,这个数组是根据找到最大值的索引下标后从原数组更新得来的,而每次的创建过程都会对时间和空间进行消耗。我在看了答案之后发现,每次可以在原数组上操作,递归函数输入参数为原数组nums和要构建子树的数组的左索引下标和右索引下标。自己写代码的过程中发现自己并不会更新索引下标,困在了左右子树不同索引下标的疑惑中,没有想清楚。问了同学之后明白了在每次递归函数的处理逻辑中,前序遍历的左子树和右子树的边界是变化的,左边是leftIndex到maxIndex-1,右边是maxIndex+1到rightIndex。这点还是需要好好理解一下的。

这篇关于代码随想录算法训练营第20天 |654.最大二叉树、 617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/930942

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

Java JDK Validation 注解解析与使用方法验证

《JavaJDKValidation注解解析与使用方法验证》JakartaValidation提供了一种声明式、标准化的方式来验证Java对象,与框架无关,可以方便地集成到各种Java应用中,... 目录核心概念1. 主要注解基本约束注解其他常用注解2. 核心接口使用方法1. 基本使用添加依赖 (Maven

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill