day83 101. 对称二叉树(Java)

83 阅读1分钟

题目来源: 101. 对称二叉树

题目描述:

  • 描述: 给你一个二叉树的根节点 root , 检查它是否轴对称
  • 难度: 简单\color{5AB726}{简单}
  • 示例:

symtree1.jpg

输入:root = [1,2,2,3,4,4,3]
输出:true

具体实现:迭代

class Solution {
    public boolean isSymmetric(TreeNode root) {
        return check(root, root);
    }

    public boolean check(TreeNode u, TreeNode v) {
        Queue<TreeNode> q = new LinkedList<TreeNode>();
        q.offer(u);
        q.offer(v);
        while (!q.isEmpty()) {
            u = q.poll();
            v = q.poll();
            if (u == null && v == null) {
                continue;
            }
            if ((u == null || v == null) || (u.val != v.val)) {
                return false;
            }

            q.offer(u.left);
            q.offer(v.right);

            q.offer(u.right);
            q.offer(v.left);
        }
        return true;
    }
}