一、题目

请实现一个函数来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。

二、解题思路

通常我们有三种不同的二叉树遍历算法,即前序遍历、中序遍历和后序遍历。在这三种遍历算法中,都是先遍历左子结点再遍历右子结点。我们是否可以定义一种遍历算法,先遍历右子结点再遍历左子结点?比如我们针对前序遍历定义一种对称的遍历算法,即先遍历父节点,再遍历它的右子结点,最后遍历它的左子结点。

我们发现可以用过比较二叉树的前序遍历序列和对称前序遍历序列来判断二叉树是不是对称的。如果两个序列一样,那么二叉树就是对称的。

三、解题代码

  1. public class Test {
  2. private static class BinaryTreeNode {
  3. private int val;
  4. private BinaryTreeNode left;
  5. private BinaryTreeNode right;
  6. public BinaryTreeNode() {
  7. }
  8. public BinaryTreeNode(int val) {
  9. this.val = val;
  10. }
  11. @Override
  12. public String toString() {
  13. return val + "";
  14. }
  15. }
  16. public static boolean isSymmetrical(BinaryTreeNode root) {
  17. return isSymmetrical(root, root);
  18. }
  19. private static boolean isSymmetrical(BinaryTreeNode left, BinaryTreeNode right) {
  20. if (left == null && right == null) {
  21. return true;
  22. }
  23. if (left == null || right == null) {
  24. return false;
  25. }
  26. if (left.val != right.val ) {
  27. return false;
  28. }
  29. return isSymmetrical(left.left, right.right) && isSymmetrical(left.right, right.left);
  30. }
  31. }