2.(101)对称二叉树

2.(101)对称二叉树

2020年3月20日

Symmetric Tree

Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center).

For example, this binary tree [1,2,2,3,4,4,3] is symmetric:

    1
   / \
  2   2
 / \ / \
3  4 4  3

But the following [1,2,2,null,3,null,3] is not:

    1
   / \
  2   2
   \   \
   3    3

Note:
Bonus points if you could solve it both recursively and iteratively.

给定一个二叉树,检查它是否是镜像对称的。

例如,二叉树 [1,2,2,3,4,4,3] 是对称的。

    1
   / \
  2   2
 / \ / \
3  4 4  3

但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:

    1
   / \
  2   2
   \   \
   3    3

说明:

如果你可以运用递归和迭代两种方法解决这个问题,会很加分。

方法1: 递归

如果一个树的左右子树是镜像对称的,那么这个树是对称的

如果同时满足以下条件,两个树互为镜像:

  1. 根节点具有相同的值
  2. 每个树的右子树都与另一个树的左子树镜像对称
public boolean isSymmetric(TreeNode root){
    return isMirror(root,root);//省略了处理root
}

public boolean isMirror(TreeNode t1,TreeNode t2){
    if(t1==null&&t2==null) return true;
    if(t1==null || t2==null) return false;
    return(t1.val==t2.val)
        && isMirror(t1.right,t2.left)
        && isMirror(t1.left,t2.right);
}

时间复杂度分析

  • 时间复杂度O(n),遍历输入树一次
  • 空间复杂度:递归调用次数受树的高度限制,在最糟糕的情况下,树是线性的,复杂度为O(n)

方法2: 迭代

除了递归的方法,我们也可以利用队列进行迭代,队列中每两个连续的结点应该是相等的,而且他们的子树互为镜像.最初,队列中包含的是root以及root.该算法的工作原理类似于BFS,但存在一些关键差异,每次提取两个结点并比较它们的值.然后,将两个结点的左右子节点按相反的顺序插入队列中,当队列为空时,或者我们检测到树不对称(即从队列中取出两个不相等的连续结点)时,该算法结束

public boolean isSymmetric(TreeNode root){
    Queue<TreeNode> q=new linkedList<>();
    q.add(root);
    q.add(root);
    while(!q.isEmpty()){
        TreeNode t1=q.poll();
        TreeNode t2=q.poll();
        if(t1==null&&t2==nll)continue;
        if(t1==null || t2==null)return false;
        if(t1.val!=t2.val)return false;
        q.add(t1.left);
        q.add(t2.right);
        q.add(t1.right);
        q.add(t2.left);
    }
    return true;
}
posted @ 2020-03-21 20:39  小苏呀  阅读(108)  评论(0编辑  收藏  举报