leetcode100.相同的树

Posted by serrini on May 11, 2022

Question

给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。

如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。

示例 1:

输入:p = [1,2,3], q = [1,2,3] 输出:true

示例 2:

输入:p = [1,2], q = [1,null,2] 输出:false

示例 3:

输入:p = [1,2,1], q = [1,1,2] 输出:false

提示:

两棵树上的节点数目都在范围 [0, 100] 内 -10⁴ <= Node.val <= 10⁴

Related Topics 树 深度优先搜索 广度优先搜索 二叉树 👍 833 👎 0

Answer

    if (p == nullptr && q == nullptr)
        return true;
    if (p == nullptr || q == nullptr)
        return false;
    if (p->val == q->val) {
        return isSameTree(p->left, q->left) && isSameTree(p->right, q->right);
    } else {
        return false;
    }

Attention

  1. 两树为空则相同,有一个为空则不同。
  2. 递归当两树根结点相同时,分别比较左右子树,左右子树都相同时才相同。