当前位置: 首页 > news >正文

LC 226.翻转二叉树

226. 翻转二叉树

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

示例 1:

输入: root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]

示例 2:

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

示例 3:

输入: root = []
输出:[]

提示:

  • 树中节点数目范围在 [0, 100]
  • − 100 ≤ N o d e . v a l ≤ 100 -100 \leq Node.val \leq 100 100Node.val100

解法一(BFS+队列)

思路分析:

  1. 对二叉树进行层序遍历,每遍历一个节点,则将其左右节点进行反转

实现代码如下:

class Solution {public TreeNode invertTree(TreeNode root) {if (root != null) {Queue<TreeNode> queue = new ArrayDeque<>();queue.offer(root);while (!queue.isEmpty()) {int size = queue.size();for (int i = 0; i < size; ++ i) {TreeNode node = queue.poll();// 进行左右节点交换TreeNode temp = node.left;node.left = node.right;node.right = temp;if (node.left != null) queue.offer(node.left);if (node.right != null) queue.offer(node.right);}}}return root;}
}

提交结果如下:

解答成功:
执行耗时:0 ms,击败了100.00% 的Java用户
内存消耗:40 MB,击败了8.36% 的Java用户

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n)

  • 空间复杂度: O ( n ) O(n) O(n)

解法二(递归)

思路分析:

  1. 对于翻转二叉树,即交换二叉树每个节点的左右子节点,即可实现翻转,交换过程具有重复性,因此考虑使用迭代和递归来实现,因为感觉递归更简单,则使用递归

  2. 首先思考递归的参数,因为实现翻转二叉树,因此参数中传递二叉树节点即可,对于返回值,因为要对二叉树进行改变,所以应该返回交换好的二叉树节点

  3. 对于递归的边界条件,即当二叉树节点为null时,返回null即可

  4. 对于交换过程,则先保存好该节点的左子节点,然后左子节点重新赋值为已经交换好的该节点的右子二叉树,同理,右子树重新赋值为已经交换好的该节点的左子二叉树

实现代码如下:

class Solution {public TreeNode invertTree(TreeNode root) {if (root != null) {root = doInvertTree(root);}return root;}private TreeNode doInvertTree(TreeNode node) {if (node == null)return null;TreeNode temp = node.left;node.left = doInvertTree(node.right);node.right = doInvertTree(temp);return node;}
}

提交结果如下:

解答成功:
执行耗时:0 ms,击败了100.00% 的Java用户
内存消耗:39.9 MB,击败了11.22% 的Java用户

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n)

  • 空间复杂度: O ( n ) O(n) O(n)

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 怀俄明探空站数据解算PWV和Tm
  • 什么是软件测试?5分钟带你快速了解!
  • JavaEE初阶-线程3
  • CentOS7:Python版本回退
  • Linux下Qt生成程序崩溃文件
  • 24双非考研哈尔滨工程大学计算机(@程程笔记)
  • hydra九头蛇
  • 海纳斯删除广告位
  • 【环境变量】基本概念理解 | 查看环境变量echo | PATH的应用和修改
  • 每日OJ题_两个数组dp①_力扣1143. 最长公共子序列
  • SpringBoot启动禁用员工账号(动态sql通用修改)
  • “大学论文数据分析全攻略:从理论到实践的实用指南“
  • Redis中的Sentinel(五)
  • FPGA的就业前景
  • 基于Java+SpringBoot+Mybaties+layui+Vue+elememt 实习管理系统 的设计与实现
  • 【翻译】Mashape是如何管理15000个API和微服务的(三)
  • Android系统模拟器绘制实现概述
  • crontab执行失败的多种原因
  • extract-text-webpack-plugin用法
  • orm2 中文文档 3.1 模型属性
  • Redis的resp协议
  • spark本地环境的搭建到运行第一个spark程序
  • Storybook 5.0正式发布:有史以来变化最大的版本\n
  • ucore操作系统实验笔记 - 重新理解中断
  • 电商搜索引擎的架构设计和性能优化
  • 前端路由实现-history
  • 前端之Sass/Scss实战笔记
  • 深入浅出webpack学习(1)--核心概念
  • 腾讯视频格式如何转换成mp4 将下载的qlv文件转换成mp4的方法
  • 优化 Vue 项目编译文件大小
  • Nginx实现动静分离
  • Salesforce和SAP Netweaver里数据库表的元数据设计
  • ​​​【收录 Hello 算法】9.4 小结
  • ​520就是要宠粉,你的心头书我买单
  • ​Python 3 新特性:类型注解
  • ​Z时代时尚SUV新宠:起亚赛图斯值不值得年轻人买?
  • ![CDATA[ ]] 是什么东东
  • # 日期待t_最值得等的SUV奥迪Q9:空间比MPV还大,或搭4.0T,香
  • ## 基础知识
  • #Datawhale AI夏令营第4期#AIGC方向 文生图 Task2
  • #QT项目实战(天气预报)
  • $NOIp2018$劝退记
  • (12)Hive调优——count distinct去重优化
  • (2/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (2022版)一套教程搞定k8s安装到实战 | RBAC
  • (delphi11最新学习资料) Object Pascal 学习笔记---第5章第5节(delphi中的指针)
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第2节(共同的基类)
  • (vue)el-cascader级联选择器按勾选的顺序传值,摆脱层级约束
  • (vue)el-tabs选中最后一项后更新数据后无法展开
  • (附源码)springboot高校宿舍交电费系统 毕业设计031552
  • (排序详解之 堆排序)
  • (七)glDrawArry绘制
  • (十)DDRC架构组成、效率Efficiency及功能实现
  • (算法)前K大的和
  • (轉貼) VS2005 快捷键 (初級) (.NET) (Visual Studio)