翻转二叉树:前序和后序的写法完全一样

一、题目很简单,但很有名

翻转二叉树就是交换每个节点的左右子节点。这道题因为 Homebrew 作者面试谷歌时没写出来而广为流传。


二、递归解法

javascript 复制代码
var invertTree = function(root) {
    if (!root) return null;
    const left = invertTree(root.left);
    const right = invertTree(root.right);
    root.left = right;
    root.right = left;
    return root;
};

这是后序写法:先递归翻转左右子树,再交换当前节点。

也可以写成前序:先交换当前节点,再递归翻转左右子树。两种都是对的,因为交换左右子树和递归翻转这两个操作是交换的。


三、BFS 迭代解法

javascript 复制代码
var invertTree = function(root) {
    if (!root) return null;
    const queue = [root];
    while (queue.length) {
        const node = queue.shift();
        [node.left, node.right] = [node.right, node.left];
        if (node.left) queue.push(node.left);
        if (node.right) queue.push(node.right);
    }
    return root;
};

用队列逐层处理,每出队一个节点就交换它的左右子节点。逻辑更直观,但要注意 shift() 在大数据量下是 O(n)。


四、复杂度

时间 O(n)------每个节点访问一次。 空间:递归 O(h),BFS O(n)。


五、总结

  1. 翻转 = 交换每个节点的左右子节点
  2. 前序和后序写法都能通过,因为交换和递归可交换
  3. 递归代码 4 行,面试首选
  4. 这道题是二叉树递归入门的最佳练习
相关推荐
用户484526255821 小时前
对称二叉树:左子树的左和右子树的右对比
排序算法
啵啵啵鱼6 天前
数组---完
算法·排序算法
嘿黑嘿呦6 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
小糯米6016 天前
JS 数组
数据结构·算法·排序算法
孬甭_7 天前
深入解析归并排序:稳定高效的分治典范
算法·排序算法
北域码匠7 天前
奇偶归并排序:并行计算的排序利器
数据结构·算法·c#·排序算法
2601_961845157 天前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
ruxshui7 天前
排序算法及不同场景应用总结
算法·排序算法
2601_961845157 天前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划