题目描述:

输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)。
第一遍没写出来错误点:认为首先应该找到pRoot1等于pRoot2的节点,但是递归就是自己在不断递归中寻找相等的节点的。判断是否相等可以完全放到另外一个函数中进行判断。主函数主要就是看结果,比较相等可以完全放到另外一个函数中去。
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};*/
class Solution {
public:
bool helper(TreeNode* pRoot1, TreeNode* pRoot2){
if(pRoot2 == nullptr){
return true;
}
if(pRoot1 == nullptr){
return false;
}
if(pRoot1 -> val != pRoot2 -> val){
return false;
}
bool left,right; left = helper(pRoot1 -> left,pRoot2 -> left);
right = helper(pRoot1 -> right,pRoot2 -> right); return left && right; } bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) {
if(pRoot1 == nullptr || pRoot2 == nullptr){
return false;
}
return helper(pRoot1,pRoot2) || helper(pRoot1 -> left,pRoot2) || helper(pRoot1 -> right,pRoot2);
}
};

最新文章

  1. Kafka Linux 安装
  2. Opencv基本数据结构
  3. HDU 1564 Play a game (找规律博弈)
  4. Torry的困惑(基本型)
  5. easy ui datagrid 动态绑定数据并绑定链接,进行操作
  6. poj 2932 Coneology(扫描线+set)
  7. [置顶] sqlplus 使用笔记
  8. FineUI布局应用(二)
  9. filter滤镜的使用
  10. Hibernate第六篇【多对多映射、一对一映射】
  11. Html5 监听拦截Android返回键方法详解
  12. [C++一本通-图论算法] 例4-4 最小花费
  13. Jmeter自带录制功能
  14. 【XSY2679】修墙 最短路
  15. js之全选即点击全选标签可选择全部复选框
  16. Express中间件,看这篇文章就够了(#^.^#)
  17. Linux安装aMule下载eDonkey200网络共享文件
  18. [Java in NetBeans] Lesson 15. Sorting and Searching.
  19. TestNG 搭建测试框架 自动化测试
  20. python 文件不存在时才能写入,读写模式xt

热门文章

  1. Euler Sums系列(二)
  2. 激活win10企业版,亲测可用,(win7步骤相同,请自行测试)
  3. 第四节:Vuejs组件及组件之间的交互
  4. DOM的一些小总结
  5. 项目中常用的全局宏定义#define
  6. java课后问题解答
  7. 登陆页面Sql注入(绕过)
  8. burpsuite使用--暴力破解
  9. centos 7中添加一个新用户并授权的步骤详解
  10. win10上安装mysql8(installer方式)并创建用户开启远程连接