HOT力扣100(43)二叉树-翻转二叉树

要翻转以 root 为根的树,先分别翻转 root 的左子树和右子树,然后把 root 的左指针指向翻转后的右子树,右指针指向翻转后的左子树。

这是典型的后序遍历思路:

  1. 先处理左子树(递归翻转左子树)
  2. 再处理右子树(递归翻转右子树)
  3. 最后处理当前节点(交换左右指针)

完整解题步骤

  1. 递归终止条件 :如果当前节点是空节点(root == nullptr),直接返回nullptr(空树不用翻转)。
  2. 递归翻转左子树 :调用invertTree(root->left),得到翻转后的左子树的根节点。
  3. 递归翻转右子树 :调用invertTree(root->right),得到翻转后的右子树的根节点。
  4. 交换当前节点的左右指针:把当前节点的左孩子指向翻转后的右子树,右孩子指向翻转后的左子树。
  5. 返回当前节点:作为翻转后的子树的根节点,返回给上一层递归
cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    TreeNode* invertTree(TreeNode* root) {
        if(root == nullptr){
            return nullptr;
        }

        TreeNode* left = invertTree(root->left);
        TreeNode* right = invertTree(root->right);
        root->left = right;
        root->right = left;

        return root;
        
    }
};
相关推荐
也曾看到过繁星1 小时前
数据结构-复杂度
数据结构
通信小呆呆1 小时前
Toeplitz结构及其快速算法详解
算法
YikNjy1 小时前
break和continue
java·开发语言·算法
春日见1 小时前
五分钟入门 强化学习---DQN(Deep Q Net)算法与实现
人工智能·python·深度学习·算法·microsoft·机器学习
budingxiaomoli2 小时前
动态规划--斐波那契数列模型
算法·动态规划
IT猿手2 小时前
多目标优化算法:多目标蛇优化算法(Multiple Objective Snake Optimizer,MOSO)(提供MATLAB代码)
开发语言·算法·matlab·动态路径规划·光伏模型参数估计
MegaDataFlowers2 小时前
101.对称二叉树
算法
Jasmine_llq2 小时前
《B3939 [GESP样题 四级] 绝对素数》
数据结构·算法·素数判断算法·数字拆分与反转算法·区间遍历枚举·双条件判断逻辑
郝学胜-神的一滴3 小时前
干货版《算法导论》07:递归视角下的选择排序与归并排序
java·数据结构·c++·python·程序人生·算法·排序算法