【剑指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;
	}
};
相关推荐
864记忆6 分钟前
项目名称:烟酒进销存管理系统
java
纪莫9 分钟前
技术面:SpringBoot(启动流程、如何优雅停机)
java·spring·java面试⑧股
仰泳的熊猫20 分钟前
LeetCode:1905. 统计子岛屿
数据结构·c++·算法·leetcode
Merrick21 分钟前
亲手操作Java抽象语法树
java·后端
初级程序员Kyle24 分钟前
开始改变第三天 Java并发(1)
java·后端
熊小猿39 分钟前
如何在 Spring Boot 项目中使用 @Slf4j 注解结合 Logback 进行系统日志管理
java·开发语言·spring boot
月夜的风吹雨1 小时前
【C++ string 类实战指南】:从接口用法到 OJ 解题的全方位解析
c++·接口·string·范围for·auto·力扣oj
OKkankan1 小时前
模板的进阶
开发语言·数据结构·c++·算法
拾光Ծ1 小时前
【高阶数据结构】哈希表
数据结构·c++·哈希算法·散列表
豐儀麟阁贵1 小时前
5.4静态变量和静态方法
java·开发语言