判断二叉树是否对称

判断二叉树是否对称

问题

这个题目说的是,给你一个二叉树,你要判断它是否沿中轴线对称。

比如说,给你的二叉树是:

     1
   /   \
  2     2
 / \   / \
4   8 8   4

这棵二叉树是沿中轴线对称的,因此要返回 true。如果我去掉最后这个 4:

     1
   /   \
  2     2
 / \   /
4   8 8

就不对称了,这时就要返回 false。

代码

public class AlgoCasts {

  public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;

    TreeNode(int x) {
      val = x;
    }
  }

  boolean isSymmetric(TreeNode s, TreeNode t) {
    if (s != null && t != null)
      return s.val == t.val &&
        isSymmetric(s.left, t.right) && isSymmetric(s.right, t.left);
    else return s == null && t == null;
  }

  // Time: O(n), Space: O(n)
  public boolean isSymmetricTreeRecursive(TreeNode root) {
    if (root == null) return true;
    return isSymmetric(root.left, root.right);
  }

  // Time: O(n), Space: O(n)
  public boolean isSymmetricTreeIterative(TreeNode root) {
    if (root == null) return true;
    Stack<TreeNode> stack = new Stack<>();
    stack.push(root.left);
    stack.push(root.right);

    while (!stack.empty()) {
      TreeNode s = stack.pop(), t = stack.pop();
      if (s == null && t == null) continue;
      if (s == null || t == null) return false;
      if (s.val != t.val) return false;

      stack.push(s.left);
      stack.push(t.right);
      stack.push(s.right);
      stack.push(t.left);
    }

    return true;
  }

}

  转载请注明: ForwardXu 判断二叉树是否对称

 上一篇
面试系列-Jvm看这篇就够了 面试系列-Jvm看这篇就够了
面试系列-Jvm看这篇就够了一. JVM基础知识1)Java 是如何实现跨平台的?注意:跨平台的是 Java 程序,而不是 JVM。JVM 是用 C/C++ 开发的,是编译后的机器码,不能跨平台,不同平台下需要安装不同版本的 JVM 答:
2018-12-29
下一篇 
检验二叉搜索树 检验二叉搜索树
检验二叉搜索树问题 这个题目说的是,给你一棵二叉树,你要判断它是不是一棵二叉搜索树。 二叉搜索树的定义是: 1. 左子树所有节点上的值都小于根节点上的值 2. 右子树所有节点上的值都大于根节点上的值 3. 左右子树同时也为二叉
2018-12-28
  目录