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 复制代码
略🤣
相关推荐
佑白雪乐2 小时前
LCR 175. 计算二叉树的深度
算法·深度优先
阿Y加油吧2 小时前
力扣打卡day07——最大子数组和、合并区间
算法
想吃火锅10052 小时前
【leetcode】105. 从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
圣保罗的大教堂2 小时前
leetcode 3567. 子矩阵的最小绝对差 中等
leetcode
2401_831824962 小时前
嵌入式C++驱动开发
开发语言·c++·算法
靠沿2 小时前
【优选算法】专题十八——BFS解决拓扑排序问题
算法·宽度优先
cui_ruicheng2 小时前
C++数据结构进阶:哈希表实现
数据结构·c++·算法·哈希算法·散列表
前端摸鱼匠2 小时前
面试题4:多头注意力(MHA)相比单头注意力的优势是什么?Head数如何影响模型?
人工智能·ai·面试·职场和发展·求职招聘
li星野2 小时前
[特殊字符] 模拟试卷一:C++核心与系统基础(90分钟)答案版
开发语言·c++·算法
二进制星轨3 小时前
leecode-283-移动零-算法题解
算法