问题描述
输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)
结果
运行时间:3ms
占用内存:468k
知识点
- 递归最难的是发现递归+递归终止条件判定;递归问题考虑从终止——>开始思考容易
- 递归问题(台阶跳,斐波那契,汉诺塔,阶乘······)+递归数据结构类型(二叉树)
- 二叉树遍历,递归思想对树的基本操作
代码
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};*/
class Solution {
public:
bool get(TreeNode* pRoot1,TreeNode* pRoot2)
{
//树的问题基本思路使用递归解决
/*
嵌套递归。。。
*/
if(pRoot2==NULL)//A子树B p2
return true;//A树 p1
if(pRoot1==NULL)
return false;
//树和子树 递归比较
if(pRoot1->val==pRoot2->val)
{
return get(pRoot1->left,pRoot2->left)&&get(pRoot1->right,pRoot2->right);
}
else
return false;
}
//有子树 返回T 无F
bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2)
{
if(pRoot1==NULL||pRoot2==NULL)
return false;
// 跟 左 右 同为T 返回T
return get(pRoot1,pRoot2)||HasSubtree(pRoot1->left,pRoot2)||HasSubtree(pRoot1->right,pRoot2);
}
};
总结
1)