博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PAT 天梯赛练习集 L2-004. 这是二叉搜索树吗?
阅读量:4480 次
发布时间:2019-06-08

本文共 1562 字,大约阅读时间需要 5 分钟。

题目链接: 

 

一棵二叉搜索树可被递归地定义为具有下列性质的二叉树:对于任一结点,

  • 其左子树中所有结点的键值小于该结点的键值;
  • 其右子树中所有结点的键值大于等于该结点的键值;
  • 其左右子树都是二叉搜索树。

所谓二叉搜索树的“镜像”,即将所有结点的左右子树对换位置后所得到的树。

给定一个整数键值序列,现请你编写程序,判断这是否是对一棵二叉搜索树或其镜像进行前序遍历的结果。

输入格式:

输入的第一行给出正整数N(<=1000)。随后一行给出N个整数键值,其间以空格分隔。

输出格式:

如果输入序列是对一棵二叉搜索树或其镜像进行前序遍历的结果,则首先在一行中输出“YES”,然后在下一行输出该树后序遍历的结果。数字间有1个空格,一行的首尾不得有多余空格。若答案是否,则输出“NO”。

输入样例1:

78 6 5 7 10 8 11

输出样例1:

YES5 7 6 8 11 10 8

输入样例2:

78 10 11 8 6 7 5

输出样例2:

YES11 8 10 7 5 6 8

输入样例3:

78 6 8 5 10 9 11

输出样例3:

NO 对于二叉搜索树中序遍历的结果唯一,因此将输入的数列从小到大、从大到小重排可以分别得到原树和镜像树的中序序列;已知前序和中序的数列可以确定一棵树,模拟建树,如果建成的树包含所有输入节点,则表示是二叉搜索树。因为数据范围1000,因此要模拟链表储存,我是用字符串'0'表示左孩子'1'表示右孩子然后对字符串建立索引作为存储下标。 代码:
#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define INF 0x3f3f3f3f#define lowbit(x) (x&(-x))#define eps 0.00000001#define pn printf("\n")using namespace std;typedef long long ll;int pre[1005];int in[1005];int n, p, b;map
mp;map
ind;int cnt = 0;void find(string S, int s, int e)// [s,e){ int k = -1; for(int i=s;i
> n; for(int i=0;i
> pre[i]; in[i] = pre[i]; } int fl = 0; { // zheng sort(in, in + n); p = 0; b = 0; find("", 0, n); if(mp.size() == n) { printf("YES\n"); fl = 1; print(""); pn; } } if(!fl) { // fan sort(in, in + n,[](int a, int b){ return a >= b;}); p = 0; b = 1; mp.clear(); find("", 0, n); if(mp.size() == n) { printf("YES\n"); fl = 1; print(""); pn; } } if(!fl) printf("NO\n");}

 

转载于:https://www.cnblogs.com/HazelNut/p/8506404.html

你可能感兴趣的文章
html如何与cgi数据交换,HTML网页与CGI之间通信的 实例分析
查看>>
html如何调用flash插件,htmlflash播放器插件如何播放 网页播放器flash插件怎么解决...
查看>>
mysql数据在html上面显示不出来的,HTML表格不能正确显示MySQL数据
查看>>
数据包和html,数据包和数据报有何区别?
查看>>
jq 异步调用一个html,聊聊如何将jQuery的$.ajax()用于异步HTTP请求
查看>>
android 7.0宽度432,全球最小的4G手机,比手掌还小,安卓7.0
查看>>
android fragmentstatepageradapter框架,Android FragmentStatePagerAdapter
查看>>
html自适应meta标签,自适应布局meta标签中viewport、content、width、initial-scale、minimum-scale、maximum-scale总结...
查看>>
html怎么加入编辑器,HTML 编辑器
查看>>
python发挥程度_你为什么用 Python?
查看>>
file 选择的文件胖多有多大_「HTML5 进阶」FileAPI 文件操作实战,内附详细案例,建议收藏...
查看>>
玄惭 mysql_阿里云数据库专家玄惭的“武功”全记录之最佳实践、双十一特别篇...
查看>>
c mysql 时间段查询_mySql 时间段查询
查看>>
mysql sql乱码怎么解决_MYSQL数据库导入SQL文件出现乱码如何解决
查看>>
mysql的存储过程与事务_mysql的存储过程与事务入门
查看>>
java程序员闯关题网站_Java程序员每周必逛的十大学习网站
查看>>
python面试装饰器_Python测开面试题之装饰器
查看>>
flashcache mysql_flashcache的实现与分析
查看>>
linux shell 里面执行python 程序_Linux下编写脚本Shell和Python的区别?
查看>>
python中if elif语句优化_python – 最有效的方式做一个if-elif-elif-else语句当else做的最多?...
查看>>