[LeetCode]—— 226——翻转二叉树

简介: [LeetCode]—— 226——翻转二叉树

1.题目



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


示例 1:


image.png


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

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

示例 2:


image.png


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

输出:[2,3,1]

示例 3:


输入:root = []

输出:[]

提示:


树中节点数目范围在 [0, 100] 内

-100 <= Node.val <= 100

2.解答


一开始翻转第二层的,他们的子树跟着过去,相当于翻转下一层的一半,就像一个数组,我们对其进行二分翻转,第一次找到中间位置,把数组分为两个部分,然后翻转,之后把左右部分接着在里面分成两个部分,对应着左右子树,翻转,直至翻转到最后只有两个元素组成的部分,翻转结束


image.png


2.代码实现分析

函数的输入是一个指向根节点的指针,输出是翻转后的二叉树的根节点指针。

首先,检查根节点是否为空。如果为空,直接返回根节点。

然后,将根节点的左子树和右子树进行交换。这可以通过创建一个临时指针来完成,将左子树指针的值赋给它,然后将左子树指针指向右子树,再将右子树指针指向临时指针。

接下来,递归地对左子树和右子树进行翻转。这样可以确保所有的子树都被翻转。

最后,返回翻转后的根节点。

该代码的时间复杂度是O(n),其中n是树中节点的个数。因为每个节点都被访问一次。

总结:该代码使用递归的方式翻转了二叉树。递归的思想是先处理当前节点,然后递归地处理其左子树和右子树。通过不断交换左子树和右子树,最终完成翻转。


3.代码实现:

1.前序

struct TreeNode* invertTree(struct TreeNode* root){
    if(root == NULL)
        return root;
    struct TreeNode* temp= root->left;;
    root->left = root->right;
    root->right = temp;
    invertTree(root->left);         
    invertTree(root->right);        
    return root;
}

2.后序

struct TreeNode* invertTree(struct TreeNode* root){
    if(root == NULL)
        return root;
 
    invertTree(root->left);         
    invertTree(root->right);  
     struct TreeNode* temp= root->left;;
    root->left = root->right;
    root->right = temp;      
    return root;
}

3.中序

struct TreeNode* invertTree(struct TreeNode* root){
    if(root == NULL)
        return root;
    invertTree(root->left);  
      struct TreeNode* temp= root->left;;
    root->left = root->right;
    root->right = temp;           
    invertTree(root->left);  
   
    return root;
}

image.png

相关文章
|
7天前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
2天前
|
算法
二刷力扣--二叉树(3)
二刷力扣--二叉树(3)
|
2天前
二刷力扣--二叉树(2)
二刷力扣--二叉树(2)
|
2天前
二刷力扣--二叉树(1)基础、遍历
二刷力扣--二叉树(1)基础、遍历
|
3天前
|
算法
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
|
7天前
|
存储 算法 数据可视化
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
|
7天前
|
算法 数据可视化 数据挖掘
LeetCode题目104: 二叉树的最大深度(递归\迭代\层序遍历\尾递归优化\分治法实现 )
LeetCode题目104: 二叉树的最大深度(递归\迭代\层序遍历\尾递归优化\分治法实现 )
LeetCode题目104: 二叉树的最大深度(递归\迭代\层序遍历\尾递归优化\分治法实现 )
|
7天前
|
存储 缓存 算法
LeetCode力扣题目111:多种算法对比实现二叉树的最小深度
LeetCode力扣题目111:多种算法对比实现二叉树的最小深度
|
7天前
|
存储 机器学习/深度学习 算法
LeetCode 题目 102:二叉树的层序遍历
LeetCode 题目 102:二叉树的层序遍历
|
7天前
|
存储 数据采集 算法
力扣题目101:对称二叉树
力扣题目101:对称二叉树