首页 > 其他分享 >LC 226.翻转二叉树

LC 226.翻转二叉树

时间:2024-04-06 13:31:25浏览次数:26  
标签:node TreeNode LC 二叉树 226 null root 节点

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 −100≤Node.val≤100

解法一(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)

标签:node,TreeNode,LC,二叉树,226,null,root,节点
From: https://blog.csdn.net/qq_61457746/article/details/137426664

相关文章

  • AI绘画:使用ComfyUI结合LCM进行实时绘图:开启AI艺术创作新篇章
    在数字艺术的世界里,ComfyUI和LCM(LatentContextualModulation)的结合为艺术家和设计师们提供了一个强大的实时绘图工具。LCM是一种先进的技术,它能够实时地将用户的输入和反馈融入到图像生成过程中,从而创造出动态变化的艺术作品。本文将作为一篇教程,引导你如何使用ComfyUI结合LC......
  • 代码随想录算法训练营DAY18|C++二叉树Part.5|513.找树左下角的值、112. 路径总和、113
    文章目录513.找树左下角的值层序-迭代遍历前中后序-递归遍历思路伪代码CPP代码112.路径总和、113.路径总和II112.路径总和思路伪代码实现CPP代码113.路径总和II思路伪代码实现CPP代码实现106\105.从中(前)序与后(中)序遍历序列构造二叉树106.从中序与后序遍历序列......
  • 数码相框-LCD显示多行文字
    显示几行文字:从左显示:先描边再算出边框。居中显示:先算出边框,再确定坐标描画。从左显示​​第一行数据的起始位置是从(0,24)开始的。​要知道第二行数据从哪里开始,我们得知道画出来的矢量字体的边框是多少:​​​​这个数据是笛卡尔坐标。​​​​测试:​​#include......
  • 数码相框-LCD显示多行文字
    显示几行文字:从左显示:先描边再算出边框。居中显示:先算出边框,再确定坐标描画。从左显示​​第一行数据的起始位置是从(0,24)开始的。​要知道第二行数据从哪里开始,我们得知道画出来的矢量字体的边框是多少:​​​​这个数据是笛卡尔坐标。​​​​测试:​​#include......
  • LCA + 树上倍增
    LCA+树上倍增一、例题引入题目:2846.边权重均等查询现有一棵由n个节点组成的无向树,节点按从0到n-1编号。给你一个整数n和一个长度为n-1的二维整数数组edges,其中edges[i]=[ui,vi,wi]表示树中存在一条位于节点ui和节点vi之间、权重为wi的边。另......
  • PLC通过Modbus转Profinet网关连接压力计的配置方法
    由于现场控制器无法正常连接压力计,咨询了解后我们通过使用Modbus转Profinet网关把连接压力计和控制顺利连接并通讯上,实现Modbus协议与Profinet协议之间的数据转换和传输,使得压力计能够无缝集成到基于Profinet的工业自动化系统中。Modbus转Profinet网关接压力计的配置方法主要包......
  • P10238 [yLCPC2024] F. PANDORA PARADOXXX
    P10238[yLCPC2024]F.PANDORAPARADOXXX并查集维护连通性+结论+数据结构维护距离题目的操作是删边通常复杂,并且不强制在线,所以离线倒过来加边。题目要求的就是当前所有连通块的直径的最大值,考虑加边后两个连通块合并后直径的变化。有结论:合并后的连通块的直径两端点一定是合......
  • 数据结构 第五章(树和二叉树)【下】
    写在前面:本系列笔记主要以《数据结构(C语言版)》为参考(本章部分图片以及知识点整理来源于王道),结合下方视频教程对数据结构的相关知识点进行梳理。所有代码块使用的都是C语言,如有错误欢迎指出。视频链接:第01周a--前言_哔哩哔哩_bilibili哈夫曼树部分的代码参考了一位小伙伴分享的......
  • STM32串行通信驱动LCD12864(使用5V电源,驱动信号用5VFT的引脚(3.3V MCU))
    #include"spi.h"voidSPI_GPIO_Init(void){//hardwaremakePSBlowtoenableserialcommunicationGPIO_InitTypeDefGPIO_InitStruct;RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);GPIO_InitStruct.GPIO_Mode=GPIO_Mo......
  • 数据结构:二叉搜索树、平衡二叉树(AVL树)、红黑树、B树、B+树
    个人理解浅谈数据结构,应对八股文面试目录前言一、二叉搜索树(二叉排序树、二叉查找树、AVL树)(1)二叉树的特点:(2)二叉树的优缺点二、平衡二叉树(高度平衡树,最早的自平衡二叉树)(1)平衡二叉树的特点:(2)平衡二叉树的优缺点三、红黑树(1)红黑树的特点(2)红黑树的优缺点四、红黑树......