【剑指offer】树的子结构
转载请注明出处:http://blog.csdn.net/ns_code/article/details/25907685
剑指offer第18题,九度OJ上測试通过!
- 题目描写叙述:
-
输入两颗二叉树A。B,推断B是不是A的子结构。
- 输入:
-
输入可能包括多个測试例子。输入以EOF结束。
对于每一个測试案例,输入的第一行一个整数n,m(1<=n<=1000,1<=m<=1000):n代表将要输入的二叉树A的节点个数(节点从1開始计数),m代表将要输入的二叉树B的节点个数(节点从1開始计数)。接下来一行有n个数,每一个数代表A树中第i个元素的数值,接下来有n行,第一个数Ki代表第i个节点的子孩子个数,接下来有Ki个树,代表节点i子孩子节点标号。接下来m+1行,与树A描写叙述同样。
- 输出:
-
相应每一个測试案例。
若B是A的子树输出”YES”(不包括引號)。否则,输出“NO”(不包括引號)。
- 例子输入:
-
7 3
8 8 7 9 2 4 7
2 2 3
2 4 5
0
0
2 6 7
0
0
8 9 2
2 2 3
0
0 1 1
2
0
3
0
- 例子输出:
-
YES
NO
- 提示:
-
B为空树时不是不论什么树的子树
在写这道题目时。卡在了測试代码上,这个题目的測试代码有点繁杂,最后參考了一哥的文章。改用数组作为存储二叉树节点的数据结构,果然写測试代码方便了非常多。
另外,程序中有一些要注意的地方。在程序中表明了凝视。
AC代码:
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h> typedef struct BTNode
{
int data;
int rchild;
int lchild;
}BTNode; /*
推断pTree2是否是与pTree1有共同的根节点的pTree1子树
*/
bool isSubTree(BTNode *pTree1,int index1,BTNode *pTree2,int index2)
{
//前两个if语句不能颠倒。不然当pTree1和pTree2同样时,会误判为false
if(index2 == -1)
return true;
if(index1 == -1)
return false;
if(pTree1[index1].data != pTree2[index2].data)
return false;
else
return isSubTree(pTree1,pTree1[index1].lchild,pTree2,pTree2[index2].lchild) &&
isSubTree(pTree1,pTree1[index1].rchild,pTree2,pTree2[index2].rchild);
} /*
推断pTree1是否包括pTree2
*/
bool isContainTree(BTNode *pTree1,int index1,BTNode *pTree2,int index2)
{
if(pTree1==NULL || pTree2==NULL)
return false;
if(index1==-1 || index2==-1)
return false; bool result = false;
if(pTree1[index1].data == pTree2[index2].data)
result = isSubTree(pTree1,index1,pTree2,index2); //假设pTree1[index1].lchild为-1。下次递归时会通过index1==-1的推断返回false,
//因此这里不须要再加上pTree1[index1].lchild!=-1的推断条件
if(!result)
result = isContainTree(pTree1,pTree1[index1].lchild,pTree2,index2);
if(!result)
result = isContainTree(pTree1,pTree1[index1].rchild,pTree2,index2); return result;
} int main()
{
int n,m;
while(scanf("%d %d",&n,&m) != EOF)
{
//输入树pTree1各节点的值
BTNode *pTree1 = NULL;
if(n>0)
{
pTree1 = (BTNode *)malloc(n*sizeof(BTNode));
if(pTree1 == NULL)
exit(EXIT_FAILURE);
int i,data;
//输入n个节点的data
for(i=0;i<n;i++)
{
scanf("%d",&data);
pTree1[i].data = data;
pTree1[i].rchild = -1;
pTree1[i].lchild = -1;
} //输入n行节点连接关系
for(i=0;i<n;i++)
{
int ki;
scanf("%d",&ki);
if(ki == 0)
continue;
else if(ki == 1)
{
int lindex;
scanf("%d",&lindex);
pTree1[i].lchild = lindex-1;
}
else
{
int lindex,rindex;
scanf("%d",&lindex);
scanf("%d",&rindex);
pTree1[i].lchild = lindex-1;
pTree1[i].rchild = rindex-1;
}
}
} //输入树pTree2各节点的值
BTNode *pTree2 = NULL;
if(m>0)
{
pTree2 = (BTNode *)malloc(m*sizeof(BTNode));
if(pTree2 == NULL)
exit(EXIT_FAILURE);
int i,data;
//输入n个节点的data
for(i=0;i<m;i++)
{
scanf("%d",&data);
pTree2[i].data = data;
pTree2[i].rchild = -1;
pTree2[i].lchild = -1;
} //输入n行节点连接关系
for(i=0;i<m;i++)
{
int ki;
scanf("%d",&ki);
if(ki == 0)
continue;
else if(ki == 1)
{
int lindex;
scanf("%d",&lindex);
pTree2[i].lchild = lindex-1;
}
else
{
int lindex,rindex;
scanf("%d",&lindex);
scanf("%d",&rindex);
pTree2[i].lchild = lindex-1;
pTree2[i].rchild = rindex-1;
}
}
} if(isContainTree(pTree1,0,pTree2,0))
printf("YES\n");
else
printf("NO\n"); }
return 0;
}
/**************************************************************
Problem: 1520
User: mmc_maodun
Language: C
Result: Accepted
Time:10 ms
Memory:912 kb
****************************************************************/
【剑指offer】树的子结构的更多相关文章
- 剑指offer——树的子结构 (JAVA代码)
版权声明:本文为博主原创文章,未经博主允许不得转载. 题目描述: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构). 解题思路: 首先看牛客网给出的测试用例: ...
- 剑指Offer 树的子结构
题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 思路: 分为2个部分.1先找出A中和B根节点相同的节点r. 2,咱判断B中所有孩子节点是不 ...
- 剑指Offer——树的子结构
题目描述: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 分析: 先匹配到A的某个结点和B的根相同,然后往下继续匹配.不匹配则递归匹配左右子树. 代码: ...
- 用js刷剑指offer(树的子结构)
题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 牛客网链接 js代码 /* function TreeNode(x) { this.val = x ...
- 剑指 offer 树的子结构
题目描述: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构). 第一遍没写出来错误点:认为首先应该找到pRoot1等于pRoot2的节点,但是递归就是自己在不 ...
- 剑指offer--24.树的子结构
时间限制:1秒 空间限制:32768K 热度指数:407165 题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) class Solution ...
- 剑指Offer-17.树的子结构(C++/Java)
题目: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 分析: 注意这道题是判断B是不是A的子结构,而不是子树,这一点要注意下,且空树不是任意一个树的子结构 ...
- [剑指Offer]26-树的子结构
题意 判断一棵树(参数二)是不是另一棵树(参数一)的子结构. 题解 递归第一棵树,找两棵树中值一样的节点.若找到后,用另一个函数判断以相同值得节点为根的树2是不是树1的子结构. 代码 class Tr ...
- 剑指offer18 树的子结构
另一种写法 class Solution { public: bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) { bool result = f ...
- 剑指offer 树的基本操作:四种遍历方式
前序遍历 递归版 编程思想 即借助系统栈,效率较低.二叉树的前序遍历规则:1. 访问根结点: 2. 遍历左子树: 3. 遍历右子树 编程实现 //树的定义 struct TreeNode { int ...
随机推荐
- 【JavaScript】强制缓存刷新
1.在js引用时加入时间戳. <script> document.write('<script src="xxx.js?_dc='+new Date().getTime() ...
- uboot编译: uboot编译配置和编译过程
jz2440: 韦东山Linux视频第1期_裸板_UBoot_文件系统_驱动初步\第09课第2节 u-boot分析之Makefile结构分析.WMV <嵌入式linux完全开发手册> 15 ...
- Hibernate MySQL 数据库 使用别名 报 Column * Not Found
使用Hibernate 查询MySQL数据表的时候报 Column Not Found ,原因是MySQL的驱动不支持别名, 解决方案如下,在连接参数中加上 useOldAliasMetadataBe ...
- ZOJ 3331 Process the Tasks 双塔Dp
用dp[i][j]表示当前安排好了前i个任务,且机器A和机器B完成当前分配到的所有任务的时间差为j(这里j可正可负,实现的时候需要加个offset)时,完成这些任务的最早时间.然后根据j的正负,分别考 ...
- 基于Sql Server 2008的分布式数据库的实践(二)
原文 基于Sql Server 2008的分布式数据库的实践(二) 从Win7连接Win2003的Sql Server 2008 1.新建链接服务器链接到Win2003的Sql Server 2008 ...
- 使用adb签名并安装Android程序
首先需要准备Android SDK包,我是在windows上操作的,在PATH中配置 YOUT_SDK_PATH\android-sdk-windows\platform-tools 和 YOUT ...
- BZOJ 2599 [IOI2011]Race【Tree,点分治】
给出N(1 <= N <= 200000)个结点的树,求长度等于K(1 <= K <= 1000000)的路径的最小边数. 点分治,这道题目和POJ 2114很接近,2114是 ...
- J2EE的13个规范之(二) JDBC 及其使用
我想大家都知道ODBC是什么?ODBC(OpenDatabaseConnectivity.开放数据库互连)是微软公司开放服务结构(WOSA,WindowsOpenServicesArchitectur ...
- .net嵌入c#代码(投票练习)
.net嵌入c#代码(投票练习) <%@ Page Language="C#" AutoEventWireup="true" CodeFile=" ...
- 网页制作之JavaScript部分 2 - DOM操作
1.DOM的基本概念 htmlDOM是一种面向对象的树的模型,它包含html中的所有元素:通过html可以找到所有包含在dom中的元素. DOM是文档对象模型,这种模型为树模型:文档是指标签文档:对 ...