转载请注明出处: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. c++ 实现将数字转换为中文数字输出

    实现如下函数: void printInChinese(int num); 这个函数输入一个小于100000000(一亿)的正整数,并在屏幕上打印这个数字的中文写法. 例如: 17 -> 一十七 ...

  2. FFmpeg源码结构图 - 解码

    ===================================================== FFmpeg的库函数源码分析文章列表: [架构图] FFmpeg源码结构图 - 解码 FFm ...

  3. jQuery 之 $(this) 出了什么问题?

    近期在写jQuery的时候出了这样一个问题? <html> <head> <title></title> </head> <style ...

  4. 将 Excel 数据导入 MySql

    能承受上万数据量,速度快,并且使用了事务,不会出现某条数据错误而导致部分数据插入(要是全部成功要是一条都不成功,测试过程中没出现失败),需要的朋友可以参考下 1.NPOI 2.MySql.Data 这 ...

  5. 【转】CentOS 6 服务器安全配置指南

    原文连接: CentOS 6 服务器安全配置指南(通用) Linux 是一个开放式系统,可以在网络上找到许多现成的程序和工具,这既方便了用户,也方便了黑客,因为他们也能很容易地找到程序和工具来潜入 L ...

  6. Google Code Jam Round 1C 2015 Problem A. Brattleship

    Problem You're about to play a simplified "battleship" game with your little brother. The ...

  7. css如何li中选中后加上class属性js控制

    <ul> <li class=""pageson"><span>1</span></li> <li> ...

  8. 设计模式 ( 十六 ) 观察者模式Observer(对象行为型)

    设计模式 ( 十六 ) 观察者模式Observer(对象行为型) 1.概述 一些面向对象的编程方式,提供了一种构建对象间复杂网络互连的能力.当对象们连接在一起时,它们就可以相互提供服务和信息. 通常来 ...

  9. 为centos添加第三方源

    默认centos自带的源少了很多好软件,所以需要添加第三方源一.安装CentOS yum源优先级插件yum-prioritiesyum install yum-plugin-priorities.no ...

  10. WTL---WxWidget---MFC 何去何从

    C++程序员打交道最多的就是MFC了,这个我不想多说,说来都是泪(C#年年更新,C++十年才出了一个featurePack还不是很好用) 现在另外两支队伍越来越庞大(所谓穷则思变,呵呵),一是WTL, ...