问题描述:对称二叉树
给定一个二叉树,检查它是否是镜像对称的。
例如,二叉树[1,2,2,3,4,4,3]
是对称的。
但是下面这个 [1,2,2,null,3,null,3]
则不是镜像对称的:
进阶:
你可以运用递归和迭代两种方法解决这个问题吗?
解决方案1:递归
- 根节点具有相同的值
- 每个树的右子树都与另一个树的左子树镜像对称
class Solution {
public boolean isSymmetric(TreeNode root) {
if (root == null) {
return true;
} else{
return check(root.left,root.right);
}
}
public boolean check(TreeNode p,TreeNode q){
if (p == null && q == null) {
return true;
}
if (p == null || q == null) {
return false;
}
return p.val == q.val && check(p.left,q.right) && check(p.right,q.left);
}
}
时间复杂度:O(n),空间复杂度:O(n)
解决方案2:迭代
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;
}
}
时间复杂度:O(n),空间复杂度:O(n)