对称二叉树:左子树的左和右子树的右对比

一、判断对称 = 判断镜像

对称二叉树不是比较每个节点的左右子节点。而是比较左子树的左子节点和右子树的右子节点 ,以及左子树的右子节点和右子树的左子节点

也就是交叉对比。


二、递归解法

javascript 复制代码
var isSymmetric = function(root) {
    if (!root) return true;
    return check(root.left, root.right);
};

function check(p, q) {
    if (!p && !q) return true;
    if (!p || !q) return false;
    if (p.val !== q.val) return false;
    return check(p.left, q.right) && check(p.right, q.left);
}

check(p.left, q.right)check(p.right, q.left)------这就是交叉对比。


三、迭代解法

javascript 复制代码
var isSymmetric = function(root) {
    if (!root) return true;
    const queue = [root.left, root.right];
    while (queue.length) {
        const p = queue.shift();
        const q = queue.shift();
        if (!p && !q) continue;
        if (!p || !q) return false;
        if (p.val !== q.val) return false;
        queue.push(p.left, q.right);
        queue.push(p.right, q.left);
    }
    return true;
};

入队顺序也是交叉的:p.left, q.rightp.right, q.left


四、复杂度

时间 O(n),空间 O(n)。


五、总结

  1. 对称 = 左子树和右子树互为镜像
  2. 交叉对比:左左 ↔ 右右,左右 ↔ 右左
  3. 递归代码最简洁,迭代用队列模拟
  4. 掌握对称二叉树 = 掌握翻转二叉树 + 判断两棵树相等
相关推荐
啵啵啵鱼6 天前
数组---完
算法·排序算法
嘿黑嘿呦6 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
小糯米6016 天前
JS 数组
数据结构·算法·排序算法
孬甭_7 天前
深入解析归并排序:稳定高效的分治典范
算法·排序算法
北域码匠7 天前
奇偶归并排序:并行计算的排序利器
数据结构·算法·c#·排序算法
2601_961845157 天前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
ruxshui7 天前
排序算法及不同场景应用总结
算法·排序算法
2601_961845157 天前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
海清河晏1118 天前
数据结构 | 八大排序
数据结构·算法·排序算法