转载请注明出处: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】树的子结构的更多相关文章

  1. 剑指offer——树的子结构 (JAVA代码)

    版权声明:本文为博主原创文章,未经博主允许不得转载. 题目描述: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构). 解题思路: 首先看牛客网给出的测试用例: ...

  2. 剑指Offer 树的子结构

    题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构)     思路: 分为2个部分.1先找出A中和B根节点相同的节点r. 2,咱判断B中所有孩子节点是不 ...

  3. 剑指Offer——树的子结构

    题目描述: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 分析: 先匹配到A的某个结点和B的根相同,然后往下继续匹配.不匹配则递归匹配左右子树. 代码: ...

  4. 用js刷剑指offer(树的子结构)

    题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 牛客网链接 js代码 /* function TreeNode(x) { this.val = x ...

  5. 剑指 offer 树的子结构

    题目描述: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构). 第一遍没写出来错误点:认为首先应该找到pRoot1等于pRoot2的节点,但是递归就是自己在不 ...

  6. 剑指offer--24.树的子结构

    时间限制:1秒 空间限制:32768K 热度指数:407165 题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构)   class Solution ...

  7. 剑指Offer-17.树的子结构(C++/Java)

    题目: 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 分析: 注意这道题是判断B是不是A的子结构,而不是子树,这一点要注意下,且空树不是任意一个树的子结构 ...

  8. [剑指Offer]26-树的子结构

    题意 判断一棵树(参数二)是不是另一棵树(参数一)的子结构. 题解 递归第一棵树,找两棵树中值一样的节点.若找到后,用另一个函数判断以相同值得节点为根的树2是不是树1的子结构. 代码 class Tr ...

  9. 剑指offer18 树的子结构

    另一种写法 class Solution { public: bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) { bool result = f ...

  10. 剑指offer 树的基本操作:四种遍历方式

    前序遍历 递归版 编程思想 即借助系统栈,效率较低.二叉树的前序遍历规则:1. 访问根结点: 2. 遍历左子树: 3. 遍历右子树 编程实现 //树的定义 struct TreeNode { int ...

随机推荐

  1. linux内核代码container_of

    它的作用显而易见,那就是根据一个结构体变量中的一个域成员变量的指针来获取指向整个结构体变量的指针. typedef unsigned int __kernel_size_t; typedef __ke ...

  2. 我的cocos2d-x集成sharesdk之旅(转)

    链接地址:http://blog.csdn.net/yeungxuguang/article/details/18227153 本文出自:http://www.iteye.com/topic/1130 ...

  3. pChart图表插件使用

    <?php /* 柱形图 */ #引入库文件 include("../class/pData.class.php"); include("../class/pDra ...

  4. ArcEngine 图层无闪烁刷新

    使用AE的同行经常会遇到这样的问题,图层刷新.目前常用的有以下几种方法: 1.完全刷新 MapControl.Refresh(); 2.局部刷新 MapControl.Refresh(esriView ...

  5. JVM--Garbage First

    Garbage First Garbage First 简称 G1,它的目标是要做到尽量减少 GC 所导致的应用暂停的时间,让应用达到准实时的效果,同时保持 JVM 堆空间的利用率,其最大的特色在于允 ...

  6. c语言memset详解

    void *memset(void *s, int ch, size_t n);(int ch可以是char或int) 将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值, 块的 ...

  7. svn笔记2

    Examining History Your Subversion repository is like a time machine. It keeps a record of every chan ...

  8. 一天一个类,一点也不累之HashSet

    最近忙着一个小项目结题,故没能按时完成[一天一个类,一点也不累],还好项目优秀,算是对自己一点点的安慰和鼓励.~~~ 今天要说的是HashSet 既然是继承自Set,那么就必须有Set的一些属性,比如 ...

  9. 利用git下载skia库

    1.准备好cygwin或者gitbash(github下载) 2.进入进入https://android.googlesource.com/,搜索skia,进入. 3.进入后最上面会显示下载方法:gi ...

  10. 基于visual Studio2013解决算法导论之004随机排列数组

     题目 随机排列数组 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <malloc.h> # ...