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

文章目录

  • 前言
  • 654.最大二叉树
    • 思路
    • 方法一 递归法
    • 方法一2 老师的+优化递归法
  • 617.合并二叉树
    • 思路
    • 方法一 递归法
    • 方法二 迭代法
  • 700.二叉搜索树中的搜索
    • 思路
    • 方法一 递归法
    • 方法二 迭代法
  • 98.验证二叉搜索树
    • 思路
    • 方法一 使用数组
    • 方法二 不使用数组
      • 代码注意点:
    • 方法二 使用双指针优化
    • 方法三 递归法
  • 总结


前言

617,98只掌握了递归法

654.最大二叉树

在这里插入图片描述
在这里插入图片描述

思路

注意事项【本题简单,就这两个重要些儿】

  1. 使用前序遍历
  2. 可以在传入的时候传入数组和左右index而不是每次都复值一个数组的方式来节省空间开销。

老师在讲的思路和我下面有一点出入:
4. 他进入递归里面的nums不为空,长度大于等于1【题目给出的】,所以在切割左右数组的时候会加了限定index>0或者index<size-1,保证nums里面有元素才递归,我的方法会有空的情况【反正没错】。

方法一 递归法

下面是自己写的代码,一遍过,和昨天的一样思路,还比昨天的简单

class Solution(object):def constructMaximumBinaryTree(self, nums):""":type nums: List[int]:rtype: TreeNode"""if not nums: return Nonemax_val = max(nums) max_index = nums.index(max_val)node = TreeNode(val=max_val)#返回条件 叶子节点;本题中因为有了上面的None的情况,所以可以省略下面这一句判断if len(nums) == 1: return node# 单层递归逻辑#拆分左右left_tree = nums[:max_index]right_tree = nums[max_index+1:]node.left = self.constructMaximumBinaryTree(left_tree)node.right = self.constructMaximumBinaryTree(right_tree)return node

方法一2 老师的+优化递归法

思路:三步走

  1. 返回node
  2. 在这里插入图片描述
  3. 有3步
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

优化:没有必要每次传入的时候都是复值的一个新的小数组,只需要传入index的起止就可以了;

class Solution:def traversal(self, nums: List[int], left: int, right: int) -> TreeNode:if left >= right:return NonemaxValueIndex = leftfor i in range(left + 1, right):#不适用max和.index函数的写法。if nums[i] > nums[maxValueIndex]:maxValueIndex = iroot = TreeNode(nums[maxValueIndex])root.left = self.traversal(nums, left, maxValueIndex)root.right = self.traversal(nums, maxValueIndex + 1, right)return rootdef constructMaximumBinaryTree(self, nums: List[int]) -> TreeNode:return self.traversal(nums, 0, len(nums))

617.合并二叉树

在这里插入图片描述
💌这是十分经典的二叉树题目;可以想想之前做过的对称二叉树;

思路

优先掌握递归法
总体思路:两棵树同步遍历+不是创建了一个新的二叉树,而是直接改的tree1;
三步递归法:

  1. 输入和返回值:输入两个tree,输出root
  2. 终止条件【💖十分巧妙】:如果t1为空,那么返回t2;如果t2为空,那就接t1
    • t1空了,肯定就是直接把后面的t2嫁接过来;当然t2为空也没有关系,那就接t2
  3. 单层逻辑:val为t1的val+t2的val;左节点为t1.left和t2.left递归之后的结果,右边也是。
  4. 补充:三种遍历顺序都是一样的

方法一 递归法

直接在t1上面处理,节省空间

class Solution(object):def mergeTrees(self, root1, root2):""":type root1: TreeNode:type root2: TreeNode:rtype: TreeNode"""if not root1:return root2if not root2:return root1root1.val += root2.valroot1.left = self.mergeTrees(root1.left,root2.left)root1.right = self.mergeTrees(root1.right,root2.right)return root1

方法二 迭代法

700.二叉搜索树中的搜索

在这里插入图片描述

思路

本题需要掌握递归法和迭代法,因为都很简单
在这里插入图片描述

方法一 递归法

三步走

  1. 传入root,传出一个是搜索数值对应的节点
  2. 终止条件:如果传入的为空的话,返回none;如果发现值相等target的话,也是直接返回root
  3. 单层递归条件:如果整个值小于root的值,进入左子树递归;大的话就是右子树
  4. 💘十分巧妙的点:终止条件里面两个可以合并,如果root==none,也是直接返回
class Solution(object):def searchBST(self, root, val):""":type root: TreeNode:type val: int:rtype: TreeNode"""if not root or root.val == val: return rootif root.val < val: result = self.searchBST(root.right)if root.val > val: result = self.searchBST(root.left)return result

方法二 迭代法

因为二叉搜索树的特性,所以很简单

class Solution:def searchBST(self, root: TreeNode, val: int) -> TreeNode:while root:if val < root.val: root = root.leftelif val > root.val: root = root.rightelse: return rootreturn None

98.验证二叉搜索树

## 题目
注意:二叉搜索树是不可以有重复的

思路

总体思路:使用中序遍历(前中后),那么遍历过程中的元素应该是单调递增的。

方法一 使用数组

方法一:定义一个全局变量list,遍历一次append一次,如果是递增数组就是对的
在这里插入图片描述

class Solution(object):def __init__(self):self.vec = []def traversal(self,root):if not root: return Trueself.traversal(root.left)self.vec.append(root.val)self.traversal(root.right)def isValidBST(self, root):""":type root: TreeNode:rtype: bool"""if not root: return Trueself.traversal(root)for i in range(1,len(self.vec)):if self.vec[i-1] >= self.vec[i]:return Falsereturn True

方法二 不使用数组

方法二:不额外申请数组占据空间的方法,遍历的过程中直接比较。
陷阱
陷阱1: 不能单纯的比较左节点小于中间节点,右节点大于中间节点就完事了;会出现下面的反面情况
在这里插入图片描述
陷阱2:
在这里插入图片描述
递归三部曲

  1. 定义全局变量记录遍历过程中的最大值,输入为root输出为bool
  2. 终止条件:如果为空节点,也是满足的。
  3. 单层遍历的逻辑:前序递归;一直更新maxVal,一旦发现maxVal >= root->val,就返回false,注意元素相同时候也要返回false;后续递归–>最后返回的应该是前序和后序遍历的结果

代码注意点:

  1. python里面设定极小值的代码为 self.maxVal = float(‘-inf’)
  2. 可以写>=的,,,,
  3. 单层中结合左右中的结果来返回。别忘了返回左右的判断结果
class Solution:def __init__(self):self.maxVal = float('-inf')  # 因为后台测试数据中有int最小值def isValidBST(self, root):if root is None:return Trueleft = self.isValidBST(root.left)# 中序遍历,验证遍历的元素是不是从小到大if self.maxVal < root.val:self.maxVal = root.valelse:return Falseright = self.isValidBST(root.right)return left and right

方法二 使用双指针优化

为了解决方法二中的担忧:如果输入的就是int的最小值怎么办,如何给maxvalue初始化呢?使用双指针法来优化
定义一个全局指针pre,单层的逻辑修改为if (pre != NULL && pre->val >= root->val) return false;pre = root; // 记录前一个节点

class Solution(object):def __init__(self):self.pre = None def isValidBST(self, root):""":type root: TreeNode:rtype: bool"""if not root: return Trueleft = self.isValidBST(root.left)if self.pre and self.pre.val >= root.val: return Falseself.pre = rootright =  self.isValidBST(root.right)return left  and right

方法三 递归法


总结

today还是太慢了。一直在玩,实验都没有怎么做。

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

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

相关文章

SecureCRT for Mac注册激活版:专业终端SSH工具

SecureCRT是一款支持SSH&#xff08;SSH1和SSH2&#xff09;的终端仿真程序&#xff0c;简单地说是Windows下登录UNIX或Linux服务器主机的软件。 SecureCRT支持SSH&#xff0c;同时支持Telnet和rlogin协议。SecureCRT是一款用于连接运行包括Windows、UNIX和VMS的理想工具。通过…

零售EDI:Target DVS EDI项目案例

Target塔吉特是美国一家巨型折扣零售百货集团&#xff0c;与全球供应商建立长远深入的合作关系&#xff0c;目前国内越来越多的零售产品供应商计划入驻Target。完成入驻资格审查之后&#xff0c;Target会向供应商提出EDI对接邀请&#xff0c;企业需要根据指示完成供应商EDI信息…

Vue学习笔记3——事件处理

事件处理 1、事件处理器&#xff08;1&#xff09;内联事件处理器&#xff08;2&#xff09;方法事件处理器 2、事件参数3、事件修饰符 1、事件处理器 我们可以使用v-on 指令(简写为)来监听DOM事件&#xff0c;并在事件触发时执行对应的JavaScript。 用法: v-on:click"me…

[自动驾驶技术]-6 Tesla自动驾驶方案之硬件(AI Day 2021)

1 硬件集成 特斯拉自动驾驶数据标注过程中&#xff0c;跨250万个clips超过100亿的标注数据&#xff0c;无论是自动标注还是模型训练都要求具备强大的计算能力的硬件。下图是特斯拉FSD计算平台硬件电路图。 1&#xff09;神经网络编译器 特斯拉AI编译器主要针对PyTorch框架&am…

【面试必看】Java并发

并发 1. 线程 1. 线程vs进程 进程是程序的一次执行过程&#xff0c;是系统运行程序的基本单位&#xff0c;因此进程是动态的。 系统运行一个程序即是一个进程从创建&#xff0c;运行到消亡的过程。在 Java 中&#xff0c;当我们启动 main 函数时其实就是启动了一个 JVM 的进…

java文档管理系统的设计与实现源码(springboot+vue+mysql)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的文档管理系统的设计与实现。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 文档管理系统的…

初学C语言100题:经典例题节选(源码分享)

1.打印Hello World! #include <stdio.h>int main() {printf("hello world\n");//使用printf库函数 注意引用头文件return 0; } 2.输入半径 计算圆的面积 int main() {float r, s;//定义变量scanf("%f", &r);//输入半径s 3.14 * r * r;// 圆的…

Android network — 进程指定网络发包

Android network — 进程指定网络发包 0. 前言1. 进程绑定网络1.1 App进程绑定网络1.2 Native进程绑定网络 2. 源码原理分析2.1 申请网络requestNetwork2.2 绑定网络 BindProcessToNetwork 3. 总结 0. 前言 在android 中&#xff0c;一个app使用网络&#xff0c;需要在manifest…

el-table 实现嵌套表格的思路及完整功能代码

要实现的需求是这样的&#xff1a; 本来我是用 el-table 的 :span-method 方法实现的&#xff0c;但发现合并起来有问题&#xff0c;跟我的需求差距有些大&#xff0c;于是我想到了嵌套表格。但是嵌套完之后的样子也是很奇怪&#xff1a; 不要气馁&#xff0c;思路还是对的&a…

InTouch历史报警、历史事件按时段查询,导出

简介&#xff1a;本插件基于上位机组态InTouch的历史报警、操作记录而开发 适用InTouch版本&#xff1a;不限 适用Windows系统&#xff1a;不限 适用数据库&#xff1a;SQL Server 标记名点数&#xff1a;不限 配套软件安装&#xff1a;Excel、WPS、SQL Server 功能&…

创新力作 焕新首发丨捷顺科技·捷曜系列智慧停车新品全新上市

2024捷顺科技智慧停车全家族新品全面上市 全新外观、全新特性、全新体验 新控制机、新道闸、新超眸相机... 每款新品都有哪些功能亮点 带您一探究竟

linux mail命令及其历史

一、【问题描述】 最近隔壁组有人把crontab删了&#xff0c;crontab这个命令有点反人类&#xff0c;它的参数特别容易误操作&#xff1a; crontab - 是删除计划表 crontab -e 是编辑&#xff0c;总之就是特别容易输入错误。 好在可以通过mail命令找回&#xff0c;但是mai…

2.冒泡排序

样例输入 5 8 3 6 4 9 样例输出 3 4 6 8 9 以下是解题答案&#xff1a; class demo1{public static void main(String[] args) {Scanner scnnew Scanner(System.in);int[] array new int[scn.nextInt()];if(array.length>0&&array.length<200){for(int…

书生·浦语大模型全链路开源体系-作业1

视频链接&#xff1a;书生浦语大模型全链路开源体系_哔哩哔哩_bilibili 1. LLM发展 LLM是近年来人工智能领域的一个重要发展方向。大型语言模型的历史可以追溯到2017年,当时OpenAI推出了GPT-1(Generative Pre-trained Transformer)模型,这是一个基于Transformer架构的语言生成…

【前端三剑客之HTML】详解HTML

1. HTML(超文本标记语言) HTML意为超文本标记语言&#xff0c;其可以通过标签把其他网页/图片/视频等资源引入到当前网页中&#xff0c;让网页最终呈现出来的效果超越了文本.HTML是一种标记语言&#xff0c;其是由一系列标签组成的. 而且每个标签都有特定的含义和确定的页面显…

LeetCode/NowCoder-链表经典算法OJ练习3

孜孜不倦&#xff1a;孜孜&#xff1a;勤勉&#xff0c;不懈怠。指工作或学习勤奋不知疲倦。&#x1f493;&#x1f493;&#x1f493; 目录 说在前面 题目一&#xff1a;返回倒数第k个节点 题目二&#xff1a;链表的回文结构 题目三&#xff1a;相交链表 SUMUP结尾 说在前…

K-means聚类算法详细介绍

目录 &#x1f349;简介 &#x1f348;K-means聚类模型详解 &#x1f348;K-means聚类的基本原理 &#x1f348;K-means聚类的算法步骤 &#x1f348;K-means聚类的优缺点 &#x1f34d;优点 &#x1f34d;缺点 &#x1f348;K-means聚类的应用场景 &#x1f348;K-mea…

全局查询筛选器适用场景 以及各场景示例

EF Core中的全局查询筛选器&#xff08;Global Query Filters&#xff09;是一种强大的功能&#xff0c;可以在实体框架的DbContext级别为特定的EntityType设置默认的过滤条件。这些筛选器自动应用于所有涉及到相关实体的LINQ查询中&#xff0c;无论是直接查询还是通过Include或…

借助 CloudFlare 增强站点内容保护防采集

今天在一位站长的帮助下实测了 CloudFlare 增强站点内容保护实现防采集的功能,效果那是杠杠的,如果您的站点原创内容比较多的话,明月强烈建议试试 CloudFlare 这个内容保护,无论是 WordPress 、Typecho 都有非常好的效果,并且几乎没有任何误伤,搜索引擎爬虫蜘蛛更是不会影…

利用边缘计算网关的工业设备数据采集方案探讨-天拓四方

随着工业4.0时代的到来&#xff0c;工业设备数据采集成为了实现智能制造、提升生产效率的关键环节。传统的数据采集方案往往依赖于中心化的数据处理方式&#xff0c;但这种方式在面对海量数据、实时性要求高的工业场景时&#xff0c;往往显得力不从心。因此&#xff0c;利用边缘…