题目

The following is from Max Howell @twitter:

Google: 90% of our engineers use the sofware you wrote (Homebrew), but you can’t invert a binary tree on a whiteboard so fuck of. Now it’s your turn to prove that YOU CAN invert a binary tree!

Input Specification:

Each input file contains one test case. For each case, the first line gives a positive integer N (<=10) which is the total number of nodes in the tree — and hence the nodes are numbered from 0 to N-1. Then N lines follow, each corresponds to a node from 0 to N-1, and gives the indices of the lef and right children of the node. If the child does not exist, a “-” will be put at the position. Any pair of children are separated by a space.

Output Specification:

For each test case, print in the first line the level-order, and then in the second line the in-order traversal sequences of the inverted tree. There must be exactly one space between any adjacent numbers, and no extra space at the end of the line.

Sample Input:

8

1 –

– –

0 –

2 7

– –

– –

5 –

4 6

Sample Output:

3 7 2 6 4 0 5 1

6 5 7 4 3 2 0 1

题目分析

已知所有节点的左右子节点,求反转二叉树的中序和后序序列

解题思路

思路 01

  1. 输入时,将左右子节点对换,即可完成反转
  2. bfs广度优先遍历,输出层序序列
  3. 递归输出中序序列

思路 02

  1. 将节点关系按照输入保存
  2. 使用后序遍历递归进行二叉树反转(也可使用前序遍历递归进行二叉树反转)
  3. bfs广度优先遍历,输出层序序列
  4. 递归输出中序序列

Code

Code 01(最优)

#include <iostream>
#include <vector>
#include <queue>
using namespace std;
const int maxn = 10;
int nds[maxn][2];
int n,cnt;
bool flag[maxn];
void bfs(int root) {
queue<int> q;
q.push(root);
while(!q.empty()) {
int now = q.front();
q.pop();
printf("%d",now);
if(++cnt<n)printf(" ");
if(nds[now][0]!=-1)q.push(nds[now][0]);
if(nds[now][1]!=-1)q.push(nds[now][1]);
}
}
void inOrder(int nd){
if(nd==-1){//nds[nd][0]==-1&&nds[nd][1]==-1
return;
}
inOrder(nds[nd][0]);
printf("%d",nd);
if(++cnt<n)printf(" ");
inOrder(nds[nd][1]);
}
int main(int argc,char * argv[]) {
char f,r;
scanf("%d",&n);
for(int i=0; i<n; i++) {
scanf("%*c%c %c",&r,&f);
if(f=='-')nds[i][0]=-1;
else {
nds[i][0]=f-'0';
flag[nds[i][0]]=true;
}
if(r=='-')nds[i][1]=-1;
else {
nds[i][1]=r-'0';
flag[nds[i][1]]=true;
} }
//find root
int k=0;
while(k<n&&flag[k])k++;
bfs(k);
printf("\n");
cnt=0;
inOrder(k);
return 0;
}

Code 02

#include <cstdio>
#include <queue>
#include <algorithm>
using namespace std;
const int maxn = 10;
struct node { // 二叉树的静态写法
int lchild, rchild;
} Node[maxn];
bool notRoot[maxn] = {false}; // 记录是否不是根结点,初始均是根结点
int n, num = 0; // n为结点个数,num为当前已经输出的结点个数
// print函数输出结点id的编号
void print(int id) {
printf("%d", id); // 输出id
num++; // 已经输出的结点个数加1
if(num < n) printf(" "); // 最后一个结点不输出空格
else printf("\n");
}
// 中序遍历
void inOrder(int root) {
if(root == -1) {
return;
}
inOrder(Node[root].lchild);
print(root);
inOrder(Node[root].rchild);
}
// 层序遍历
void BFS(int root) {
queue<int> q; //注意队列里是存地址
q.push(root); //将根结点地址入队
while(!q.empty()) {
int now = q.front(); //取出队首元素
q.pop();
print(now);
if(Node[now].lchild != -1) q.push(Node[now].lchild); //左子树非空
if(Node[now].rchild != -1) q.push(Node[now].rchild); //右子树非空
}
}
// 后序遍历,用以反转二叉树
//void postOrder(int root) {
// if(root == -1) {
// return;
// }
// postOrder(Node[root].lchild);
// postOrder(Node[root].rchild);
// swap(Node[root].lchild, Node[root].rchild); // 交换左右孩子
//}
// 前序遍历,用以反转二叉树
void preOrder(int root) {
if(root == -1) {
return;
}
swap(Node[root].lchild, Node[root].rchild); // 交换左右孩子
preOrder(Node[root].lchild);
preOrder(Node[root].rchild);
}
// 将输入的字符转换为-1或者结点编号
int strToNum(char c) {
if(c == '-') return -1; // “-”表示没有孩子结点,记为-1
else {
notRoot[c - '0'] = true; // 标记c不是根结点
return c - '0'; // 返回结点编号
}
}
// 寻找根结点编号
int findRoot() {
for(int i = 0; i < n; i++) {
if(notRoot[i] == false) {
return i; // 是根结点,返回i
}
}
}
int main() {
char lchild, rchild;
scanf("%d", &n); // 结点个数
for(int i = 0; i < n; i++) {
scanf("%*c%c %c", &lchild, &rchild); // 左右孩子
Node[i].lchild = strToNum(lchild);
Node[i].rchild = strToNum(rchild);
}
int root = findRoot(); // 获得根结点编号
// postOrder(root); // 后序遍历,反转二叉树
preOrder(root); // 前序遍历,反转二叉树
BFS(root); // 输出层序遍历序列
num = 0; // 已输出的结点个数置0
inOrder(root); // 输出中序遍历序列
return 0;
}

PAT Advanced 1102 Invert a Binary Tree (25) [树的遍历]的更多相关文章

  1. PAT甲级——1102 Invert a Binary Tree (层序遍历+中序遍历)

    本文同步发布在CSDN:https://blog.csdn.net/weixin_44385565/article/details/90577042 1102 Invert a Binary Tree ...

  2. 1102. Invert a Binary Tree (25)

    The following is from Max Howell @twitter: Google: 90% of our engineers use the software you wrote ( ...

  3. PAT (Advanced Level) 1102. Invert a Binary Tree (25)

    简单题. #include<cstdio> #include<cstring> #include<cmath> #include<vector> #in ...

  4. PAT甲题题解-1102. Invert a Binary Tree (25)-(建树,水题)

    就是把输入给的左孩子右孩子互换一下,然后输出层次遍历和中序遍历. #include <iostream> #include <algorithm> #include <c ...

  5. 【PAT甲级】1102 Invert a Binary Tree (25 分)(层次遍历和中序遍历)

    题意: 输入一个正整数N(<=10),接着输入0~N-1每个结点的左右儿子结点,输出这颗二叉树的反转的层次遍历和中序遍历. AAAAAccepted code: #define HAVE_STR ...

  6. PAT (Advanced Level) 1110. Complete Binary Tree (25)

    判断一棵二叉树是否完全二叉树. #include<cstdio> #include<cstring> #include<cmath> #include<vec ...

  7. PAT 1102 Invert a Binary Tree[比较简单]

    1102 Invert a Binary Tree(25 分) The following is from Max Howell @twitter: Google: 90% of our engine ...

  8. 1102 Invert a Binary Tree——PAT甲级真题

    1102 Invert a Binary Tree The following is from Max Howell @twitter: Google: 90% of our engineers us ...

  9. PAT 1102 Invert a Binary Tree

    The following is from Max Howell @twitter: Google: 90% of our engineers use the software you wrote ( ...

随机推荐

  1. Java Break 与 Continue

    章节 Java 基础 Java 简介 Java 环境搭建 Java 基本语法 Java 注释 Java 变量 Java 数据类型 Java 字符串 Java 类型转换 Java 运算符 Java 字符 ...

  2. nginx做维护页面

    需求: 一个网站本来有好几个域名,然后也有好几个二级域名,现在停掉了,要求把所有的域名.二级域名,以及具体的文件请求,都指向一个维护页面. 1 单独在vhost里建一个conf文件 server { ...

  3. 如何用naviecat批量创建mysql数据

    1.参考博文:https://blog.csdn.net/lelly52800/article/details/87267096 2.excel要与表结构一致 3.右键,导入向导,选择相应版本,点击“ ...

  4. HihoCoder第十四周:无间道之并查集

    #1066 : 无间道之并查集 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 这天天气晴朗.阳光明媚.鸟语花香,空气中弥漫着春天的气息--额,说远了,总之,小Hi和小H ...

  5. USB2.0主机控制器 UPD720114 简单详解

    UPD720114 是符合 USB 2.0规格的集线器控制器,适用于“符合生态原则的解决方案”.这种小型封装的控制器集成了核心逻辑电路的2.5 V 内部电压调整器.终端电阻器,减少了所需要的外部组件的 ...

  6. String巩固

    About String in Java 如今做了一个重大决定,不定期温习The Basement Of Java String对象的认知简述 首先 String不属于 8种基本数据类型, Strin ...

  7. 雷火神山直播超两亿,Web播放器事件监听是怎么实现的?

    Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播.在视频业务大数据平台中,播放数据的统计分析非常重要,所以We ...

  8. Apache nifi 第一篇(概述)

    1.什么是Apache NiFi? 简单地说,NiFi是为了自动化系统之间的数据流.虽然数据流这种形式很容易理解,但我们在此使用它来表示系统之间的自动化和不同系统之间数据的流转.企业拥有多个系统,其中 ...

  9. distpicker.js 根据当前位置初始化select

    学习参考的地址放在最醒目的地方: https://blog.csdn.net/idea_boy/article/details/58280076 百度官方实例:http://developer.bai ...

  10. 【LeetCode】206. 反转链表

    题目 反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可 ...