判断二叉树是否相同

判断二叉树是否相同

问题

这个题目说的是,给你两个二叉树,你要判断它们是否相同。这里所谓相同,指的是两棵树结构相同,并且相应节点上的数值相等。

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

   1          1
  / \        / \
 2   4      2   4

它们的结构相同,相应节点上的值也相等,因此返回 true。 如果另一棵树是:

   1
  / \
 2   5

或

    1
   /
  2
 /
4

两棵树则不相同,返回 false。

代码

public class AlgoCasts {

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

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

  // Time: O(n), Space: O(n)
  public boolean isSameTreeRecursive(TreeNode p, TreeNode q) {
    if (p == null && q == null) return true;
    if (p == null || q == null) return false;
    return p.val == q.val &&
      isSameTreeRecursive(p.left, q.left) &&
      isSameTreeRecursive(p.right, q.right);
  }

  // Time: O(n), Space: O(n)
  public boolean isSameTreeIterative(TreeNode p, TreeNode q) {
    Stack<TreeNode> stack = new Stack<>();
    stack.push(p);
    stack.push(q);

    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.left);
      stack.push(s.right);
      stack.push(t.right);
    }

    return true;
  }

}

  转载请注明: ForwardXu 判断二叉树是否相同

 上一篇
检验二叉搜索树 检验二叉搜索树
检验二叉搜索树问题 这个题目说的是,给你一棵二叉树,你要判断它是不是一棵二叉搜索树。 二叉搜索树的定义是: 1. 左子树所有节点上的值都小于根节点上的值 2. 右子树所有节点上的值都大于根节点上的值 3. 左右子树同时也为二叉
2018-12-28
下一篇 
合并二叉树 合并二叉树
合并二叉树问题 这个题目说的是,给你两棵二叉树,你要把它们合并起来形成一棵新的二叉树。合并规则是对应节点上的数字相加得到新节点的数字,如果有一个节点为空,则直接使用非空节点的数字,如果两个节点都为空,则合并后也为空。 比如说,给你的两棵二叉
2018-12-28
  目录