题目

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. printf的封装与实现

    1 UART通信协议 1.1 UART通信的物理连接 图1 UART的物理连接 1.2 逻辑电平 用电平表示逻辑1和逻辑0,逻辑1和逻辑0用来组织计算机层面的数据. 1.3 电平标准 根据通讯使用的电 ...

  2. Problem J. Joseph’s Problem 约瑟夫问题--余数之和

    链接:https://vjudge.net/problem/UVA-1363 题意:给出n  k,当 i 属于 1~n 时 ,求解 n% i 的和 n 和 k 的范围都是 1 到 10^9; 商相同 ...

  3. 史上最全的mysql聚合函数总结(与分组一起使用)

    1.首先我们需要了解下什么是聚合函数 聚合函数aggregation function又称为组函数. 认情况下 聚合函数会对当前所在表当做一个组进行统计. 2.聚合函数的特点 1.每个组函数接收一个参 ...

  4. Adapter之ArrayAdapter以及监听器设置

    前言: ArrayAdapter:支持泛型操作,最简单的一个Adapter,只能展现一行文字~,我的学习就是通过这个最简单的适配器开始 正文: 完成这个ArrayAdapter需要三步:1.初始化数据 ...

  5. S7-300位逻辑指令仿真练习 停车场

    第三章 S7-300 指令应用 位逻辑指令 M存储器 在PLC中M存储区(也称位存储区,又称内部存储器标志位(M)存储器区),它属于系统存储区.在你选定具体的CPU型号后,可以查看CPU的技术规格,其 ...

  6. HDU - 6198 number number number(规律+矩阵快速幂)

    题意:已知F0 = 0,F1 = 1,Fn = Fn - 1 + Fn - 2(n >= 2), 且若n=Fa1+Fa2+...+Fak where 0≤a1≤a2≤⋯≤a,n为正数,则n为mj ...

  7. 机器学习(ML)一之 Linear Regression

    一.线性回归 1.模型 2.损失函数 3.优化函数-梯度下降 #!/usr/bin/env python # coding: utf-8 import torch import time # init ...

  8. /和//的区别(python)

    /  除 得到的是浮点数,结果是大数的时候会使用科学计数法 但是 / 会在遇到大数时候运算不准确 因为将两个int相除会产生一个浮点数,并且除法的确切结果不能精确地表示为float. 精确结果必须四舍 ...

  9. 移动端触屏click点击事件延迟问题,以及tap的解决方案

    在移动端 触屏click事件虽然也会响应,但是总感觉是有延迟,一直听说click事件在手机上有200~300毫秒的延迟问题,亲自测了一下,在pc端模拟手机的话是测不出来的,但是用手机测试时发现延迟非常 ...

  10. 分享一个php加密字符串类。

    class base64{ /** * 加密字符串 * @access static * @param string $data 字符串 * @param string $key 加密key * @r ...