AcWing 37. 树的子结构
2024-09-06 04:47:25
题目描述 地址https://www.acwing.com/problem/content/35/
输入两棵二叉树A,B,判断B是不是A的子结构。
我们规定空树不是任何树的子结构。
样例
树A: / \ / \ / \ 树B: / \ 返回 true ,因为B是A的子结构。
算法1
一看到题目就想到 首先遍历A树(hasSubtree())
以每个点作为根节点和B树的节点比较 看看是否相同(issame())
如果和B树每个节点的值都相同(issame() 递归到B树节点为NULL) 那么就是有B结构的子树
C++ 代码
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
bool IsSame(TreeNode* pRoot1, TreeNode* pRoot2)
{
if( pRoot2 == NULL) return true;
if( pRoot1 == NULL ) return false; if(pRoot1->val != pRoot2->val) return false; return IsSame(pRoot1->left ,pRoot2->left) && IsSame(pRoot1->right,pRoot2->right);
} bool hasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) {
if ( NULL == pRoot1 || NULL == pRoot2) return false; if( IsSame(pRoot1,pRoot2) ) return true; if( hasSubtree(pRoot1->right,pRoot2) ) return true;
if( hasSubtree(pRoot1->left,pRoot2) ) return true; return false;
}
}; 作者:defddr
链接:https://www.acwing.com/solution/acwing/content/3540/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
最新文章
- Devexpress Ribbon Add Logo
- 错误:java.util.Map is an interface, and JAXB can't handle interfaces.
- codeforces 360 E - The Values You Can Make
- 基于吉日嘎底层架构的通用权限管理Web端UI更新:参考DTcms后台界面
- SuSE Linux 开启VNC服务
- <;转>;RowState 介绍
- Hello Struts2
- 简约的单页应用引擎:sonnyJS
- jq 幻灯片插件制作
- 一:ZooKeeper简介
- ubuntu - sudo in php exec
- Linux/UNIX环境下Oracle数据库多实例开机启动脚本(转)
- (原)css 响应式媒体查询 模板
- Linux C编程一站式学习读书笔记——socket编程
- Thinking in scala (8)---- 乘幂计算
- nodejs npm常用命令 转
- win10常用快捷键
- Windows系统XAMPP安装Moodle教程
- 无法在正在进行内容生成时调用 StartAt
- EOS商业落地利器:多签名操作与应用