Symmetric Tree
Given a binary tree, check whether it is a mirror of itself(ie, symmetric around its center)
For example, this tree is symmetric:
1
/ \
2 2
/ \ / \
3 4 4 3
But the following tree is not.
1
/ \
2 2
\ \
3 3
public boolean isSymmetric(TreeNode root) {
if (root == null) {
return true;
}
return helper(root.left, root.right);
}
private boolean helper(TreeNode left, TreeNode right) {
if (left == null && right == null) {
return true;
}
if (left == null || right == null) {
return false;
}
return (left.val == right.val) && helper(left.left, right.right)
&& helper(left.right, right.left);
}