Keshawn_lu's Blog

Leetcode 100. 相同的树

字数统计: 296阅读时长: 1 min
2020/08/07 Share

题目简介:

给定两个二叉树,编写一个函数来检验它们是否相同。

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

示例 1:

1
2
3
4
5
6
7
输入:       1         1
/ \ / \
2 3 2 3

[1,2,3], [1,2,3]

输出: true

示例 2:

1
2
3
4
5
6
7
输入:      1          1
/ \
2 2

[1,2], [1,null,2]

输出: false

示例 3:

1
2
3
4
5
6
7
输入:       1         1
/ \ / \
2 1 1 2

[1,2,1], [1,1,2]

输出: false

思路:

深度优先搜索,当两个结点有一个为空,一个不为空,或两个结点的val值不同时,返回false

若两个结点都为空,返回true

最后返回isSameTree(p -> left, q -> left) && isSameTree(p -> right, q -> right)即可。

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
bool isSameTree(TreeNode* p, TreeNode* q) {

if(!p && !q)
return true;

if(!q)
return false;

if(!p)
return false;

if(p -> val != q -> val)
return false;

return isSameTree(p -> left, q -> left) && isSameTree(p -> right, q -> right);

}
};
CATALOG
  1. 1. 题目简介:
  2. 2. 思路:
  3. 3. 代码如下: