剑指offer.树的子结构
Contents
面试题26. 树的子结构
姐妹篇
输入两棵二叉树A和B,判断B是不是A的子结构。(约定空树不是任意一个树的子结构)
B是A的子结构, 即 A中有出现和B相同的结构和节点值。g
例如: 给定的树 A:
3 / \
4 5 /
1 2 给定的树 B:4 / 1 返回 true,因为 B 与 A 的一个子树拥有相同的结构和节点值。
示例 1:
输入:A = [1,2,3], B = [3,1] 输出:false 示例 2:
输入:A = [3,4,5,1,2], B = [4,1] 输出:true 限制:
0 <= 节点个数 <= 10000
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/shu-de-zi-jie-gou-lcof 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题解:
- 复习此题目时,可以放在和 04.10检查子树 放在一块看
- 不同之处之在与 子结构 与 子树的区别
- 想法
- 本来想着,此题目跟 04.10检查子树一模一样
- 无非是检查子树
- 要么两棵树 A 和 B一样
- 要么 递归检查 A.left 和 B一样
- 要么 递归检查 A.right 和 B一样
- 提交
- 提交后,此测试用例未通过
- [10,12,6,8,3,11] [10,12,6,8]
- 提交后,此测试用例未通过
- 问题
- 为什么提交后,未通过呢?因为 子结构 与 子树不一样
- 子结构 :A(或者A的子树) 包含 B
- 子树 : A(或者A的子树) 和 B相同
- 为什么提交后,未通过呢?因为 子结构 与 子树不一样
- 修改
- 不判断两棵树完全相等, 而是判断 A是否包含 B
代码如下 :
|
|
Author 飞熊
LastMod Jun 17