翻转二叉树

时间复杂度是线性的,需要遍历每个节点。空间复杂度是线性的,最坏情况递归深度是线性的,即单链的情况。

  1. 本质是自底向上,递归到最底层,然后交换。
  2. 左子树更新为递归之后的右子树
  3. 右子树更新为递归之后的左子树
  4. 根始终保持不动
c 复制代码
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;
    }
};
相关推荐
金牌归来发现妻女流落街头25 分钟前
【LeetCode 第207题】
算法·leetcode·拓扑·领接表
alphaTao2 小时前
LeetCode 每日一题 2026/5/25-2026/5/31
算法·leetcode
菜菜的顾清寒2 小时前
力扣HOT100(41)动态规划-杨辉三角
算法·leetcode·动态规划
happymaker06262 小时前
LeetCodeHot100——盛水最多的容器
数据结构·算法·leetcode·双指针·hot100
过期动态2 小时前
【LeetCode 热题 100】三数之和
java·数据结构·算法·leetcode·职场和发展·排序算法
z200509302 小时前
今日算法(回溯找IP,加检测)
算法·leetcode
sheeta19982 小时前
LeetCode 补拙笔记 日期:2026.05.29 题目:1559. 二维网格图中探测环
笔记·算法·leetcode
罗超驿2 小时前
10.滑动窗口解决:无重复字符的最长子串 | LeetCode 3 Java 题解
java·算法·leetcode·面试
罗超驿2 小时前
8.【LeetCode 18】四数之和 —— Java 排序 + 双指针解法详解
算法·leetcode·职场和发展
菜菜的顾清寒3 小时前
HOT100力扣(40) 动态规划-爬楼梯
算法·leetcode·动态规划