数据结构实验之查找一:二叉排序树

Time Limit: 400MS Memory Limit: 65536KB

Problem Description

对应给定的一个序列可以唯一确定一棵二叉排序树。然而,一棵给定的二叉排序树却可以由多种不同的序列得到。例如分别按照序列{3,1,4}和{3,4,1}插入初始为空的二叉排序树,都得到一样的结果。你的任务书对于输入的各种序列,判断它们是否能生成一样的二叉排序树。

Input

输入包含若干组测试数据。每组数据的第1行给出两个正整数N (n < = 10)和L,分别是输入序列的元素个数和需要比较的序列个数。第2行给出N个以空格分隔的正整数,作为初始插入序列生成一颗二叉排序树。随后L行,每行给出N个元素,属于L个需要检查的序列。
简单起见,我们保证每个插入序列都是1到N的一个排列。当读到N为0时,标志输入结束,这组数据不要处理。

Output

对每一组需要检查的序列,如果其生成的二叉排序树跟初始序列生成的二叉排序树一样,则输出"Yes",否则输出"No"。

Example Input

4 2
3 1 4 2
3 4 1 2
3 2 4 1
2 1
2 1
1 2
0

Example Output

Yes
No
No

DQE:

二叉排序树,开始理解错题意了233
 
 #include <iostream>
#include <cstdio>
using namespace std; struct Tree
{
int x;
Tree *lt,*rt;
}; void insert(Tree *&root,int e)
{
if(!root)
{
Tree *r=new Tree;
r->x=e;
r->lt=r->rt=NULL;
root=r;
}
else
{
if(e<root->x)
insert(root->lt,e);
else if(e>root->x)
insert(root->rt,e);
}
} bool cmp(Tree *r,Tree *r2)
{
if(r==NULL&&r2==NULL)
return true;
else if(r==NULL||r2==NULL)
return false;
if(r->x!=r2->x)
return false;
return cmp(r->lt,r2->lt)&&cmp(r->rt,r2->rt);
} int main()
{
int n,l;
while(scanf("%d",&n),n!=)
{
scanf("%d",&l);
Tree *root=NULL;
int i;
for(i=;i<=n;i++)
{
int e;
scanf("%d",&e);
insert(root,e);
}
int j;
for(j=;j<=l;j++)
{
Tree *r2=NULL;
for(i=;i<=n;i++)
{
int e;
scanf("%d",&e);
insert(r2,e);
}
if(cmp(root,r2))
printf("Yes\n");
else
printf("No\n");
}
}
return ;
} /***************************************************
User name: ***
Result: Accepted
Take time: 0ms
Take Memory: 152KB
Submit time: 2016-11-29 16:54:54
****************************************************/

最新文章

  1. VB.NET中图像处理的一些技巧以及其和C#图像处理的差距。
  2. Android开发之XUtils框架使用和报错处理
  3. Entity Framework 与ORACLE ODP.Net 在vs2010下的稀奇古怪的问题
  4. 企业云部署要如何选择IaaS PaaS和SaaS
  5. centos一键优化脚本
  6. QQ登入(4)QQ分享-内容转载
  7. 在dom4j中使用XPath
  8. Windows下使用Visual Studio Code搭建Go语言环境
  9. JavaScript创建Map对象(转)
  10. ORA-00054
  11. Python 手册——开胃菜
  12. tomcat配置接口访问时间
  13. webview之如何设计一个优雅健壮的Android WebView?(下)(转)
  14. 软工网络15团队作业4——Alpha阶段敏捷冲刺8.0
  15. 7 -- Spring的基本用法 -- 8... 抽象Bean与子Bean;Bean继承与Java继承的区别;容器中的工厂Bean;获得Bean本身的id;强制初始化Bean
  16. MySQL double 类型查询不准确的问题
  17. 如何在office2010中的EXCEL表格使用求和公式
  18. EqualsBuilder 类的使用
  19. java_I/O字符流
  20. KMP + 求最小循环节 --- HUST 1010 - The Minimum Length

热门文章

  1. Codeforces Round #246 (Div. 2) C. Prime Swaps(贪心,数论)
  2. 关于stl advance函数移动步数超过容器大小(越界)的研究
  3. bzoj 3907 网格 bzoj2822 [AHOI2012]树屋阶梯——卡特兰数(阶乘高精度模板)
  4. 第四篇 PHP的成长路线
  5. JavaScript函数的默认参数(default parameter)
  6. shell脚本中常用命令
  7. CentOS7网卡设置为桥接模式静态IP配置方法详解
  8. AJAX,jQuery Ajax和Deferred
  9. Cache-Control头
  10. 【转】 Pro Android学习笔记(八二):了解Package(1):包和进程