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