6.4翻转二叉树(LC226—送分题,前序遍历)

算法:
第一想法是用昨天的层序遍历,把每一层level用切片反转。但是这样时间复杂度很高。
其实只要在遍历的过程中去翻转每一个节点的左右孩子就可以达到整体翻转的效果。
这道题目使用前序遍历和后序遍历都可以,唯独中序遍历不方便,因为中序遍历会把某些节点的左右孩子翻转了两次!建议拿纸画一画,就理解了
注意:是指针进行交换,交换的是左右孩子,然后里面的值再交换
首先使用递归法,代码简单:
调试过程:

原因:root没有迭代,一直都是有值的根节点。有递归了,其实不用while循环了。
正确代码:
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:def invertTree(self, root: Optional[TreeNode]) -> Optional[TreeNode]:#root是每一个节点变量,不一定是根节点if root == None:return Noneelse:#交换左右孩子指针(V)root.left, root.right = root.right, root.left#L,每个子树下面的节点进一步进行左右交换if root.left:root.left = self.invertTree(root.left)#R,每个子树下面的节点进一步进行左右交换if root.right:root.right = self.invertTree(root.right)return root
时间空间复杂度:
`invertTree`函数的时间复杂度是O(n),其中n是二叉树中的节点数。这是因为我们对每个节点进行一次访问,并且对每个节点执行固定量的工作。
`invertTree`函数的空间复杂度是O(h),其中h是二叉树的高度。这是因为函数使用递归,递归的最大深度等于树的高度。在最坏的情况下,即树完全不平衡且类似于链表的情况下,树的高度等于节点数,导致空间复杂度为O(n)。然而,在平衡的二叉树中,高度通常是log(n),导致空间复杂度为O(log(n))。
面试官看你顺畅的写出了递归,一般会进一步考察能不能写出相应的迭代
我觉得迭代法就是要加循环:
使用迭代的方式来翻转二叉树。我们从根节点开始,将根节点入栈。然后,进入循环,直到栈为空。在循环中,我们从栈中弹出一个节点,并交换其左右子节点的指针。如果存在左子节点,则将其入栈,如果存在右子节点,则将其入栈。
`stack`用于迭代地翻转二叉树。它起到了存储待处理节点的作用。
使用栈的迭代方法相比于递归方法,可以减少递归调用的开销,同时也可以避免递归的最大深度限制。
递归的最大深度限制是什么?
递归的最大深度限制是指递归调用的层数上限。每次进行递归调用时,系统会在内存中为该函数分配一段栈空间,用于保存函数的局部变量、参数和返回地址等信息。当递归的层数过多时,栈空间会被耗尽,导致栈溢出错误。
不同的编程语言和操作系统对递归的最大深度限制可能有所不同。在Python中,默认的最大递归深度是1000层,超过这个限制将引发"RecursionError"异常。可以使用`sys.setrecursionlimit()`函数来修改Python的递归深度限制,但是需要注意修改深度限制可能会导致栈溢出错误。
为了避免递归的最大深度限制,可以使用迭代的方法来替代递归,或者使用尾递归优化等技术来减少递归调用的层数。
正确代码:
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:def invertTree(self, root: Optional[TreeNode]) -> Optional[TreeNode]:#root是根节点if root == None:return Noneelse:stack = [root]#交换左右孩子指针(V)while stack:#将node定义为每个节点node = stack.pop()#交换node.left, node.right = node.right, node.left#L,将node.left存入stack,这样循环时pop出来,进行子节点的交换if node.left:stack.append(node.left) #R,每个子树下面的节点进一步进行左右交换if node.right:stack.append(node.right) return root
时间空间复杂度:
时间复杂度:
- 遍历每个节点并交换其左右子节点的指针需要O(n)的时间,其中n是二叉树中的节点数。
空间复杂度:
- 使用了一个栈来存储待处理节点,最坏情况下,栈的大小与二叉树的高度成正比,即O(h),其中h是二叉树的高度。
- 在最坏情况下,当二叉树是一个单链表时,树的高度等于节点数,因此空间复杂度为O(n)。
- 在平衡的二叉树中,树的高度通常是log(n),因此空间复杂度为O(log(n))。
综上所述,该解决方案的时间复杂度为O(n),空间复杂度为O(h)或O(n)。
相关文章:
6.4翻转二叉树(LC226—送分题,前序遍历)
算法: 第一想法是用昨天的层序遍历,把每一层level用切片反转。但是这样时间复杂度很高。 其实只要在遍历的过程中去翻转每一个节点的左右孩子就可以达到整体翻转的效果。 这道题目使用前序遍历和后序遍历都可以,唯独中序遍历不方便&#x…...
【斗罗二】霍雨浩拿下满分碾压戴华斌,动用家族力量,海神阁会议
Hello,小伙伴们,我是小郑继续为大家深度解析国漫资讯。 深度爆料《绝世唐门》第23话最新预告分析,魂兽升学考试中一场白虎魂师戴华斌与千年级别的风虎的决斗即将上演。风虎,作为虎类魂兽的王者,其强大的实力和独特的技能让这场战…...
通义千问, 文心一言, ChatGLM, GPT-4, Llama2, DevOps 能力评测
引言 “克隆 dev 环境到 test 环境,等所有服务运行正常之后,把访问地址告诉我”,“检查所有项目,告诉我有哪些服务不正常,给出异常原因和修复建议”,在过去的工程师生涯中,也曾幻想过能够通过这…...
一键创建PDF文档,高效管理您的文件资料
在繁忙的工作中,您是否曾为处理PDF文件而感到烦恼?现在,我们为您推荐一款全新的高效PDF文档管理工具——一键创建PDF文档,让您的工作效率瞬间提升! 首先,在首助编辑高手的主页面板块栏里,选择“…...
React在 JSX 中进行条件渲染和循环,并使用条件语句和数组的方法(如 map)来动态生成组件或元素
在 JSX 中进行条件渲染和循环,你可以使用条件语句(如 if-else)和数组的方法(如 map)来动态生成组件或元素。以下是一些示例来说明这些概念: 条件渲染: import React from react;const MyCompo…...
数据结构-二叉树的遍历及相关应用
1、定义二叉树结点结构 2、编写主程序 3、三种方法遍历二叉树,并实现求树的深度,叶子数,某一层的结点数 4、实现代码(带交互界面) #include<iostream> using namespace std; typedef struct BiTNode {char d…...
机器人入门(五)—— 仿真环境中操作TurtleBot
仿真环境中操作TurtleBot 一、实操1.1 查看姿态信息1.2 控制turtlebot移动的三种方式1.2.1 命令行发布指令1.2.2 键盘操控1.2.3 Python脚本控制1.2.4 使用rqt工具界面,发布运动指令 二、里程计(odometry)TurtleBot3 仿真 进行实操之前,先准备环境 $ sud…...
G2406C是一款高效的直流-直流降压开关稳压器,能够提供高达1A输出电流。
G2406C 1.5MHz,1A高效降压DC-DC转换器 概述: G2406C是一款高效的直流-直流降压开关稳压器,能够提供高达1A输出电流。G2406C在2.7V至5.5V的宽范围输入电压下工作,使IC是低压电源转换的理想选择。在1.5MHz的固定频率下运行允许使用具有小电感…...
HTB——常见端口及协议总结
文章目录 一、 常见端口二、HTTP协议三、FTP四、SMB 一、 常见端口 http协议:80、8000https协议:443、8443ftp协议:20(数据传输)、21(发送命令)smb协议:445 二、HTTP协议 https的…...
Spring Boot中处理简单的事务
说到事务,我们第一影响应该是数据库管理系统的一个重要概念。 事务(Transaction)是数据库管理系统(DBMS)中的一个概念,用于管理对数据库的一组操作,这些操作要么全部成功执行,要么全…...
source activate my_env 和conda activate my_env 有什么区别
source activate my_env 和conda activate my_env 有什么区别 source activate 和 conda activate 是两个不同的命令,用于在Conda环境中激活特定的虚拟环境。它们的区别在于它们分别适用于不同版本的Conda。 source activate: source activate 是在Con…...
机器学习模型超参数优化最常用的5个工具包!
优化超参数始终是确保模型性能最佳的关键任务。通常,网格搜索、随机搜索和贝叶斯优化等技术是主要使用的方法。 今天分享几个常用于模型超参数优化的 Python 工具包,如下所示: scikit-learn:使用在指定参数值上进行的网格搜索或…...
出口美国操作要点汇总│走美国海运拼箱的注意事项│箱讯科技
01服务标准 美国的货物需要细致的服务,货物到港后的服务也是非常重要的。如果在货物到港15天内,如果没有报关行进行(PROCEED),货物就会进入了G.O.仓库,G.O.仓库的收费标准是非常高的。 02代理资格审核 美国航线除了各家船公司&a…...
Gateway网关
Gateway网关 1、网关的位置与作用 官网:Spring Cloud Gateway Geteway是Zuul的替代, Zuul:路由和过滤Zuul最终还是会注册到Eureka Zuul网关采用同步阻塞模式不符合要求。 Spring Cloud Gateway基于Webflux,比较完美地支持异步…...
Python Opencv实践 - 车牌定位(纯练手,存在失败场景,可以继续优化)
使用传统的计算机视觉方法定位图像中的车牌,参考了部分网上的文章,实际定位效果对于我目前使用的网上的图片来说还可以。实测发现对于车身本身是蓝色、或是车牌本身上方有明显边缘的情况这类图片定位效果较差。纯练手项目,仅供参考。代码中im…...
U盘插在电脑上显示要格式化磁盘怎么办
U盘是一种便携式存储设备,广泛应用于各种场合。然而,有时候我们可能会遇到一些问题,比如将U盘插入电脑后显示要格式化磁盘,这通常意味着U盘的分区出现了问题或者U盘的文件系统已经损坏。这种情况下,我们应该如何解决呢…...
Python使用腾讯云SDK实现对象存储(上传文件、创建桶)
文章目录 1. 开通服务2. 创建存储桶3. 手动上传文件并查看4. python上传文件4.1 找到sdk文档4.2 初始化代码4.3 region获取4.4 secret_id和secret_key获取4.5 上传对象代码4.6 python实现上传文件 5 python创建桶 首先来到腾讯云官网 https://cloud.tencent.com/1. 开通服务 来…...
Springboot整合Jedis实现单机版或哨兵版可切换配置
Springboot整合Jedis实现单机版或哨兵版可切换配置 前言实现最后 前言 前文写到借助redis实现Shiro实现session限制登录数量踢人下线,本文就写一下Jedis的配置,可切换单机版和集群哨兵版,方便开发测试。 实现 很简单,直接上代码&…...
lenovo联想小新 Air-14 2019 AMD平台API版(81NJ)原装出厂Windows10系统
下载链接:https://pan.baidu.com/s/1HCC66EH4UOcgofRx5_v1oA?pwdlgqw 提取码:lgqw 原厂系统自带所有驱动、出厂主题壁纸、系统属性专属LOGO标志、Office办公软件、联想电脑管家等预装程序 所需要工具:16G或以上的U盘 文件格式…...
特殊矩阵的压缩存储(对称矩阵,三角矩阵,三对角矩阵,稀疏矩阵)
目录 1.数组的存储结构1.—维数组2.二维数组1.行优先存储2.列优先存储 2.特殊矩阵1.对称矩阵1.行优先存储 2.三角矩阵1.上三角矩阵2.下三角矩阵 3.三对角矩阵(带状矩阵)4.稀疏矩阵 1.数组的存储结构 1.—维数组 各数组元素大小相同,且物理上…...
Mac新手必看:保姆级Git+SourceTree配置指南,从安装到拉取代码一气呵成
Mac新手必看:保姆级GitSourceTree配置指南,从安装到拉取代码一气呵成 刚接触开发的Mac用户,面对Git命令行操作往往一头雾水。SourceTree作为图形化工具能大幅降低学习门槛,但初始配置过程仍可能让新手手足无措。本文将用最直观的方…...
网络工程师必看:H3C与华为认证体系的前世今生及备考选择指南
网络工程师职业认证全攻略:H3C与华为认证体系深度解析与选择策略 1. 认证体系的历史渊源与技术基因 2003年那场跨国知识产权诉讼,意外催生了中国企业网络设备认证体系的分野。当时华为与3COM合资成立的华为3COM(后更名H3C)&#x…...
告别编译噩梦:用CMake一次搞定OpenCV 4.5.3 + contrib + VTK 9.0.3的完整开发环境
构建跨平台计算机视觉开发环境:CMake整合OpenCV与VTK的最佳实践 在计算机视觉与三维可视化结合的复杂项目中,开发环境的搭建往往成为第一道技术门槛。传统的手动编译方式不仅耗时费力,更难以保证不同平台间的可复现性。本文将分享如何通过CMa…...
IAR 9.2 主题设置踩坑实录:从字体失效到关键字高亮,我的完整配置流程
IAR 9.2 主题定制深度指南:从字体陷阱到语法高亮优化 第一次在IAR 9.2中尝试自定义主题时,我本以为会像其他主流IDE那样简单——直到发现字体设置完全失效、关键字高亮混乱不堪。经过三天反复试验和源码分析,终于摸清了这套主题系统的运作机制…...
从Overleaf回归本地:我为什么选择TeXLive+WinEdt搭建更高效的LaTeX写作环境?
从Overleaf回归本地:为什么TeXLiveWinEdt能打造更高效的LaTeX工作流? 当你在深夜赶论文时突然遭遇Overleaf服务器崩溃,或是需要自定义某个冷门宏包却受限于在线环境权限,那种无力感足以让任何LaTeX用户重新思考工具链的选择。作为…...
Arduino 运行异常的 7 个典型诱因与规避策略
1. 函数调用过载引发的崩溃 Arduino最常见的崩溃场景之一就是函数调用堆栈溢出。这个问题特别容易出现在递归函数设计中,我曾经在一个温控项目中就踩过这个坑。当时为了计算温度变化趋势,我写了个递归函数,结果设备运行不到半小时就自动重启。…...
从一次‘背锅’经历讲起:我是如何用VRRP+静态路由搞定小型企业网络冗余的
从一次‘背锅’经历讲起:我是如何用VRRP静态路由搞定小型企业网络冗余的 那是个周一的早晨,市场部的电话直接打爆了我的手机——CRM系统集体掉线,正在进行的客户演示被迫中断。当我气喘吁吁跑到机房时,老旧的边缘路由器指示灯正在…...
Keil5中开启GNU扩展的3个隐藏技巧(附STM32实战配置)
Keil5中开启GNU扩展的3个隐藏技巧(附STM32实战配置) 在嵌入式开发领域,Keil MDK作为ARM架构的主流开发环境,其默认的ARM编译器虽然高效,但有时我们需要利用GNU工具链特有的语法扩展和功能特性。特别是在跨平台开发、使…...
Python医学图像分割评估实战:MedPy核心指标详解与应用
1. 医学图像分割评估为什么需要量化指标? 在医学影像分析领域,图像分割的质量直接影响后续诊断和治疗方案的制定。想象一下,如果医生需要评估一个脑肿瘤分割算法,仅靠肉眼观察两张分割结果图(算法预测结果和专家标注的…...
OpenCore技术革命:重新定义旧Mac硬件再生的开源创新范式
OpenCore技术革命:重新定义旧Mac硬件再生的开源创新范式 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 在苹果生态系统中,硬件生命周…...
