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 | 1 |
But the following [1,2,2,null,3,null,3] is not:
1 | 1 |
Note
Bonus points if you could solve it both recursively and iteratively.
Recursive
1 | public class TreeNode { |
1 | public boolean isSymmetric(TreeNode root) { |
Iterative
1 | public class TreeNode { |
1 | public boolean isSymmetric(TreeNode root) { |