美文网首页
101. Symmetric Tree

101. Symmetric Tree

作者: juexin | 来源:发表于2017-01-07 13:47 被阅读0次

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.

public class Solution {
    public boolean isSymmetric(TreeNode root) {
        return root != null? Symmetric(root.left,root.right):true;
    }
    private boolean Symmetric(TreeNode L,TreeNode R)
    {
        if(L==null&&R==null)
           return true;
        if(L==null||R==null)  // 已经将都是null相等的情况排除了
           return false;
        return L.val == R.val&&Symmetric(L.left,R.right)&&Symmetric(L.right,R.left);
    }
}

相关文章

网友评论

      本文标题:101. Symmetric Tree

      本文链接:https://www.haomeiwen.com/subject/ngkfbttx.html