题目

A Binary Search Tree (BST) is recursively defined as a binary tree which has the following properties: The lef subtree of a node contains only nodes with keys less than the node’s key. The right subtree of a node contains only nodes with keys greater than or equal to the node’s key. Both the lef and right subtrees must also be binary search trees. If we swap the lef and right subtrees of every node, then the resulting tree is called the Mirror Image of a BST. Now given a sequence of integer keys, you are supposed to tell if it is the preorder traversal sequence of a BST or the mirror image of a BST.

Input Specification:

Each input file contains one test case. For each case, the first line contains a positive integer N (<=1000). Then N integer keys are given in the next line. All the numbers in a line are separated by a space.

Output Specification:

For each test case, first print in a line “YES” if the sequence is the preorder traversal sequence of a BST or the mirror image of a BST, or “NO” if not. Then if the answer is “YES”, print in the next line the postorder traversal sequence of that tree. All the numbers in a line must be separated by a space, and there must be no extra space at the end of the line.

Sample Input 1:

7

8 6 5 7 10 8 11

Sample Output 1:

YES

5 7 6 8 11 10 8

Sample Input 2:

7

8 10 11 8 6 7 5

Sample Output 2:

YES

11 8 10 7 5 6 8

Sample Input 3:

7

8 6 8 5 10 9 11

Sample Output 3:

NO

题目分析

已知二叉查找树节点序列,判断是其前序序列还是其镜像树的前序序列,并打印相应树的后序序列

解题思路

思路 01

  1. 输入测试数据时,分别建树和建镜像树
  2. 先用树的先序序列与原测试序列对比,若同即输出YES,若不同再用镜像树先序序列对比,若同输出YES,不同则NO
  3. 若为YES,打印相应后序序列

思路 02(最优、难理解)

  1. 输入测试数据时,建树
  2. 根据二叉查找树的性质(大于所有左子树节点,小于所有右子树节点)

    2.1 获取后序序列,若后序序列中的结点数与原测试用例结点数相同,即为二叉查找树的先序序列打印YES,若不同,清空,并进性镜像树的后序序列获取

    2.2 获取镜像树的后序序列结点数,若与原测试用例结点数相同,即为二叉查找树镜像树的先序序列YES,若不同,打印NO
  3. 若为YES,打印相应后序序列

知识点

二叉查找树的前序转后序,无需建树,可根据其性质(大于所有左子树节点,小于所有右子树节点)建树

如前序序列:8 6 5 7 10 8 11

8是根节点

左子树:从6开始往后找小于8的都为8的左子树节点

右子树:从最后一位11开始往前找大于8的都为8的右子树节点

继续递归过程,直到完成建树

Code

Code 01

#include <iostream>
#include <vector>
using namespace std;
struct node {
int data;
node * left=NULL;
node * right=NULL;
node() {}
node(int _data):data(_data) {}
};
node * root,* rootM;
void insert(int n, int b) {
if(root==NULL&&b==0) {
root = new node(n);
return;
}
if(rootM==NULL&&b==1) {
rootM = new node(n);
return;
}
node * p;
if(b==0)p=root;
else p=rootM;
while(p!=NULL) {
if((n<p->data&&b==0)||(n>=p->data&&b==1)) {
if(p->left==NULL) {
p->left=new node(n);
return;
}
p=p->left;
} else if((n>=p->data&&b==0)||(n<p->data&&b==1)) {
if(p->right==NULL) {
p->right=new node(n);
return;
}
p=p->right;
}
}
}
vector<int> origin,pre,post,preM,postM;
void preOrder(node * nd, int b) {
if(nd==NULL)return;
if(b==0)pre.push_back(nd->data);
else preM.push_back(nd->data);
preOrder(nd->left,b);
preOrder(nd->right,b);
}
void postOrder(node * nd, int b) {
if(nd==NULL)return;
postOrder(nd->left,b);
postOrder(nd->right,b);
if(b==0)post.push_back(nd->data);
else postM.push_back(nd->data);
}
int main(int argc,char * argv[]) {
int n,m;
scanf("%d",&n);
for(int i=0; i<n; i++) {
scanf("%d",&m);
origin.push_back(m);
insert(m,0);
insert(m,1);
}
// int flag = -1;//0 前序;1 镜像前序;2 NO
preOrder(root,0);
preOrder(rootM,1);
if(pre==origin) {
postOrder(root,0);
printf("YES\n");
for(int i=0; i<post.size(); i++) {
if(i!=0)printf(" ");
printf("%d",post[i]);
}
} else if(preM==origin) {
if(preM==origin) {
postOrder(rootM,1);
printf("YES\n");
for(int i=0; i<postM.size(); i++) {
if(i!=0)printf(" ");
printf("%d",postM[i]);
}
}
}else{
printf("NO\n");
}
return 0;
}

Code 02(最优、难理解)

#include <iostream>
#include <vector>
using namespace std;
vector<int> pre,post;
bool isMirror;
void getPost(int root, int tail) {
if(root>tail)return;
int i=root+1;
int j=tail;
if(!isMirror) {
while(i<=tail&&pre[i]<pre[root])i++;
while(j>root&&pre[j]>=pre[root])j--;
} else {
while(i<=tail&&pre[i]>=pre[root])i++;
while(j>root&&pre[j]<pre[root])j--;
}
if(i-j!=1)return;
getPost(root+1,j);//左子树
getPost(i,tail); //右子树
post.push_back(pre[root]);
}
int main(int argc,char * argv[]) {
int n,m;
scanf("%d",&n);
for(int i=0; i<n; i++) {
scanf("%d",&m);
pre.push_back(m);
}
getPost(0,n-1);
if(post.size()!=n) {
isMirror=true;
post.clear();
getPost(0,n-1);
}
if(post.size()==n) {
printf("YES\n%d",post[0]);
for(int i=1; i<post.size(); i++) {
printf(" %d",post[i]);
}
} else {
printf("NO\n");
}
return 0;
}

PAT Advanced 1043 Is It a Binary Search Tree (25) [⼆叉查找树BST]的更多相关文章

  1. PAT Advanced 1099 Build A Binary Search Tree (30) [⼆叉查找树BST]

    题目 A Binary Search Tree (BST) is recursively defined as a binary tree which has the following proper ...

  2. PAT Advanced 1064 Complete Binary Search Tree (30) [⼆叉查找树BST]

    题目 A Binary Search Tree (BST) is recursively defined as a binary tree which has the following proper ...

  3. PAT 甲级 1043 Is It a Binary Search Tree (25 分)(链表建树前序后序遍历)*不会用链表建树 *看不懂题

    1043 Is It a Binary Search Tree (25 分)   A Binary Search Tree (BST) is recursively defined as a bina ...

  4. 【PAT】1043 Is It a Binary Search Tree(25 分)

    1043 Is It a Binary Search Tree(25 分) A Binary Search Tree (BST) is recursively defined as a binary ...

  5. PAT 甲级 1043 Is It a Binary Search Tree

    https://pintia.cn/problem-sets/994805342720868352/problems/994805440976633856 A Binary Search Tree ( ...

  6. PAT 1043 Is It a Binary Search Tree (25分) 由前序遍历得到二叉搜索树的后序遍历

    题目 A Binary Search Tree (BST) is recursively defined as a binary tree which has the following proper ...

  7. 1043 Is It a Binary Search Tree (25分)(树的插入)

    A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...

  8. PAT (Advanced Level) 1043. Is It a Binary Search Tree (25)

    简单题.构造出二叉搜索树,然后check一下. #include<stdio.h> #include<algorithm> using namespace std; +; st ...

  9. PAT (Advanced Level) 1099. Build A Binary Search Tree (30)

    预处理每个节点左子树有多少个点. 然后确定值得时候递归下去就可以了. #include<cstdio> #include<cstring> #include<cmath& ...

随机推荐

  1. CodeForces - 755C PolandBall and Forest (并查集)

    题意:给定n个数,Ai的下标为1~n.对于每一个i,Ai与i在同一个树上,且是与i最远的点中id最小的点(这个条件变相的说明i与Ai连通).求森林中树的个数. 分析:若i与Ai连通,则在同一个树上,因 ...

  2. GNS3 模拟icmp端口不可达

    R1 : conf t int f0/0 no shutdown ip add 192.168.1.1 255.255.255.0 no ip routing end R2 f0/0: conf t ...

  3. Mybatis 向MySql数据库插入带有日期类型字段的数据

    我们的实体类里面一个字段的日期类型是util.Date,在向数据库插入该实体时会报错,说是 日期哪个字段 Data truncation.所以需要做些更改在mybatis的MAPPER映射文件中对插入 ...

  4. 在Windows中安装vim

    这篇文章主要教大家如何在Windows系统下安装最好用的编辑器VIM 来自百度百科的介绍: Vim是一个类似于Vi的著名的功能强大.高度可定制的文本编辑器,在Vi的基础上改进和增加了很多特性. VIM ...

  5. Bootstrap 侧边栏 导航栏

    http://blog.csdn.net/shangmingchao/article/details/49763351 实测效果图:

  6. VUE- 异步等待方法嵌套

    VUE- 异步等待方法嵌套 vue在一个方法执行完后执行另一个方法用Promise来实现.Promise是ES6的新特性,用于处理异步操作逻辑,用过给Promise添加then和catch函数,处理成 ...

  7. 【Android】家庭记账本手机版开发报告三

    一.说在前面 昨天 对第一天的框架结构进行了四方面的完善 今天 对界面显示和逻辑结构进行完善 问题 无 二.界面展示完善 1.使用可回收的列表recyclerView展示账单的信息,并设置数据项为卡片 ...

  8. 外部 Storage Provider【转】

    如果 Kubernetes 部署在诸如 AWS.GCE.Azure 等公有云上,可以直接使用云硬盘作为 Volume,下面是 AWS Elastic Block Store 的例子: 要在 Pod 中 ...

  9. POJ 2182&& POJ 2828:Lost Cows 从后往前 线段树

    Lost Cows Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10544   Accepted: 6754 Descri ...

  10. nginx报错

    1. nginx报错 nginx: [error] invalid PID number "" in "/usr/local/nginx/logs/nginx.pid&q ...