【剑指offr--C/C++】JZ26 树的子结构

一、题目

二、分析

要判断一个树是不是另一个树的子树,这里边存在两个递归--

第一个:确定一个根节点,A树中任意一个节点都有可能是子树的根节点,若当前节点不是,那么就要将其左右子树分别作为根节点走相同的判断流程;

第二个:选择一个节点之后,将以这个节点为根的整棵树取出来与B进行比较,比较时根节点与左右子节点比较的方式是相同的。

所以我们要写两个函数,来完成两个递归。

三、代码

cpp 复制代码
/*
struct TreeNode {
	int val;
	struct TreeNode *left;
	struct TreeNode *right;
	TreeNode(int x) :
			val(x), left(NULL), right(NULL) {
	}
};*/
class Solution {
public:

    bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) {
     //第一个递归 选择一个节点作为比较的根
        if(pRoot2==NULL) return false;  //空树不是任意一个树的子树
		if(pRoot1==NULL && pRoot2!=NULL) return false;
		if(isSon(pRoot1,pRoot2))  return true;
		if(HasSubtree(pRoot1->left, pRoot2)) return true;
		if(HasSubtree(pRoot1->right, pRoot2)) return true;
		return false;

    }

	bool isSon(TreeNode* root1, TreeNode* root2){
	//第二个递归,比较这个树上的每一个节点
		 if(root2==NULL) return true;  
		 if(root1==NULL && root2!=NULL) return false;
		 if(root1->val!=root2->val) return false;
		 bool left=isSon(root1->left, root2->left);
		 bool right=isSon(root1->right, root2->right);
		 if(left && right ) return true;
		 return false;
	}
};
相关推荐
zc.z27 分钟前
JAVA实现:纯PCM格式音频转换成BASE64
java·音视频·pcm
mask哥1 小时前
力扣算法java实现汇总整理(上)
java·算法·leetcode
袁雅倩19971 小时前
当吸尘器、筋膜枪都用上Type-C,供电方案该怎么选?浅谈PD取电芯片ECP5702的应用
c语言·开发语言·支持向量机·动态规划·推荐算法·最小二乘法·图搜索算法
Aaswk2 小时前
Java Lambda 表达式与流处理
java·开发语言·python
是宇写的啊2 小时前
Spring AOP
java·spring
万邦科技Lafite2 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之字符串 --【子串查找】:[NOIP 2009 提高组] 潜伏者
c++·字符串·csp·高频考点·信奥赛·子串查找·潜伏者
初願致夕霞3 小时前
基于系统调用的Linux网络编程——UDP与TCP
linux·网络·c++·tcp/ip·udp
Mr_pyx4 小时前
Spring AI 入门教程:Java开发者的AI应用捷径
java·人工智能·spring
Zephyr_04 小时前
Leedcode算法题
java·算法