剑指Offer刷题(树的子结构)
程序员文章站
2022-06-16 18:01:06
剑指Offer刷题(树的子结构)一.题目描述二.代码(C++)三.提交记录四.备注一.题目描述输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)二.代码(C++)/*struct TreeNode {int val;struct TreeNode *left;struct TreeNode *right;TreeNode(int x) :val(x), left(NULL), right(NULL) {}};*/class S...
一.题目描述
输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)
二.代码(C++)
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};*/
class Solution {
private:
bool mate(TreeNode* pRoot1,TreeNode* pRoot2)
{
if(!pRoot2)
return true;
if(!pRoot1 || pRoot1->val!=pRoot2->val)
return false;
return mate(pRoot1->left,pRoot2->left) && mate(pRoot1->right,pRoot2->right);
}
public:
bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2)
{
if(!pRoot2 || !pRoot1)
return false;
return mate(pRoot1,pRoot2) || HasSubtree(pRoot1->left,pRoot2) || HasSubtree(pRoot1->right,pRoot2);
}
};
三.提交记录
四.备注
注意题意表述不清,如果B已经迭代完,A还有子数,也判定B是A的子结构。
本文地址:https://blog.csdn.net/Umbraner/article/details/107251100
推荐阅读
-
[算法练习-剑指offer]题18.二叉树的镜像(Java)
-
力扣OJ 剑指 Offer 68 - II. 236. 二叉树的最近公共祖先
-
20200329-剑指offer-面试题48. 最长不含重复字符的子字符串(滑动窗口)
-
剑指 Offer 42. 连续子数组的最大和——从这题开始学习动态规划
-
剑指 Offer 07. 重建二叉树——【前中序】和【中后序】重建二叉树的递归思路详解
-
剑指 Offer 55 - I. 二叉树的深度——DFS+BFS解题
-
leetcode 113 剑指offer 面试题34. 二叉树中和为某一值的路径(python3)
-
剑指offer面试题68 - I. 二叉搜索树的最近公共祖先(python)
-
剑指Offer之连续子数组的最大和
-
剑指offer——连续子数组的最大和