226. 翻转二叉树 LeetCode 热题 HOT 100

目录

过程解析

一、题目理解

题目要求将一棵二叉树镜像翻转,即对每个节点交换其左右子树位置。

翻转操作核心是:

对当前节点执行:交换左右子树。

不同遍历方法只是操作顺序不同。


二、前序遍历(根 → 左 → 右)

  • 先访问当前节点,并立即交换左右子树;
  • 然后递归处理交换后的左子树和右子树。
  • 翻转顺序是自顶向下进行。

三、中序遍历(左 → 根 → 右)

  • 先递归翻转左子树;
  • 回到当前节点时交换左右子树;
  • 然后递归处理交换后的右子树。
  • 操作在访问根节点时进行,左右指针结构会发生变化。

四、后序遍历(左 → 右 → 根)

  • 先递归翻转左子树;
  • 再递归翻转右子树;
  • 最后在当前节点交换左右子树。
  • 翻转顺序是自底向上进行。

五、层序遍历(按层访问)

  • 使用队列,从根节点开始逐层访问;
  • 每访问一个节点,立即交换它的左右子树;
  • 将子节点加入队列,等待后续访问。
  • 翻转顺序是从上到下、按层进行。

代码

C++

先序遍历
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) return nullptr;
        // 先序遍历
        TreeNode *rightTree = root->right;
        root->right = root->left;
        root->left = rightTree;
        invertTree(root->left);
        invertTree(root->right);
        return root;
    }
};
中序遍历
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) return nullptr;
        // 中序遍历
        invertTree(root->left);
        TreeNode* tmp = root->left;
        root->left = root->right;
        root->right = tmp;
        invertTree(root->left);//左右已经交换了此处仍然使用左子树
        return root;
    }
};
后序遍历
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) return nullptr;
        // 后序遍历
        TreeNode *left = invertTree(root->left);
        TreeNode *right = invertTree(root->right);
        root->right = left;
        root->left = right;
        return root;
    }
};
层序遍历
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) return nullptr;
        // 层序遍历
        queue<TreeNode*> q;
        q.push(root);
        while(!q.empty()){
            TreeNode *node = q.front();
            q.pop();
            swap(node->left,node->right);
            if(node->left) q.push(node->left);
            if(node->right) q.push(node->right);
        }
        return root;
    }
};

C语言

c 复制代码
略🤣
相关推荐
Allen_LVyingbo8 分钟前
量子测量三部曲:投影测量、POVM 与坍缩之谜—从形式主义到物理图像
算法·性能优化·健康医疗·量子计算·空间计算
qiqsevenqiqiqiqi13 分钟前
位运算 计算
算法
甄心爱学习24 分钟前
【最优化】1-6章习题
人工智能·算法
PD我是你的真爱粉25 分钟前
向量数据库原理与检索算法入门:ANN、HNSW、LSH、PQ 与相似度计算
数据库·人工智能·算法
汀、人工智能27 分钟前
[特殊字符] 第72课:杨辉三角
数据结构·算法·数据库架构·图论·bfs·杨辉三角
_深海凉_36 分钟前
LeetCode热题100- 字母异位词分组
leetcode
洛水水38 分钟前
【力扣100题】14.两数相加
c++·算法·leetcode
我不是小upper40 分钟前
相关≠因果!机器学习中皮尔逊相关检验的完整流程
人工智能·算法·机器学习
float_com41 分钟前
LeetCode80. 删除有序数组中的重复项 II
leetcode
pwn蒸鱼43 分钟前
leetcode:21. 合并两个有序链表
算法·leetcode·链表