HRBUST 2040 二叉树的遍历
本题有多组数据,输入处理到文件结束。
每组数据的第一行包括一个整数n,表示这棵二叉树一共有n个节点。
接下来的一行每行包括n个整数,表示这棵树的中序遍历。
接下来的一行每行包括n个整数,表示这棵树的前序遍历。
3<= n <= 100
Output
4 2 5 1 6 3 7
1 2 4 5 3 6 7
Sample Output
#include <stdio.h>
#include <stdlib.h>
typedef struct Node {
int Data;
struct Node *Left,*Right;
}Node;
int q[],z[];///q记录前序遍历 z记录中序遍历
Node* creatNode() {
Node *node = (Node *)malloc(sizeof(Node));
if(node == NULL) exit();
node -> Left = node -> Right = NULL;
return node;
}
Node* rTree(int q1,int q2,int z1,int z2) {
Node *node = creatNode();
node -> Data = q[q1];
for(int i = z1;i <= z2;i ++) {
if(z[i] == q[q1]) {
if(i != z1) node -> Left = rTree(q1 + ,q1 + i - z1,z1,i - );
if(i != z2) node -> Right = rTree(q1 + i - z1 + ,q2,i + ,z2);//右儿子构建
break;
}
}
return node;
}
//void postOrder(Node *node) {
// if(node == NULL) return;
// postOrder(node -> Left);
// postOrder(node -> Right);
// printf("%d ",node -> Data);
//}
//void postOrder(Node *node) {///下标标记
// Node *s[100];
// char num[100] = {0};
// int c = 0;
// s[c ++] = node;
// while(c) {
// Node *temp = s[c - 1];
// if(num[c - 1]) {
// num[c - 1] = 0;
// printf("%d ",s[-- c] -> Data);
// }
// else {
// num[c - 1] = 1;
// if(temp -> Right) {
// s[c ++] = temp -> Right;
// }
// if(temp -> Left) {
// s[c ++] = temp -> Left;
// }
// }
// }
//}
void postOrder(Node *node) {///前驱结点判断
Node *s[],*la;
int c = ;
s[c ++] = node;
while(c) {
Node *temp = s[c - ];
if(temp -> Left == temp -> Right && temp -> Left == NULL || la == temp -> Left || la == temp -> Right) {
printf("%d ",s[-- c] -> Data);
la = temp;
}
else {
if(temp -> Right && la != temp -> Right) {
s[c ++] = temp -> Right;
}
if(temp -> Left && la != temp -> Left) {
s[c ++] = temp -> Left;
}
}
}
}
int main() {
int n;
Node *tree;
while(~scanf("%d",&n)) {
for(int i = ;i < n;i ++) {
scanf("%d",&z[i]);
}
for(int i = ;i < n;i ++) {
scanf("%d",&q[i]);
}
tree = rTree(,n - ,,n - );
postOrder(tree);
putchar('\n');
}
return ;
}
HRBUST 2040 二叉树的遍历的更多相关文章
- 二叉树的遍历(递归,迭代,Morris遍历)
二叉树的三种遍历方法: 先序,中序,后序,这三种遍历方式每一个都可以用递归,迭代,Morris三种形式实现,其中Morris效率最高,空间复杂度为O(1). 主要参考博客: 二叉树的遍历(递归,迭代, ...
- C++ 二叉树深度优先遍历和广度优先遍历
二叉树的创建代码==>C++ 创建和遍历二叉树 深度优先遍历:是沿着树的深度遍历树的节点,尽可能深的搜索树的分支. //深度优先遍历二叉树void depthFirstSearch(Tree r ...
- 二叉树的遍历(递归,迭代,Morris遍历)
二叉树的遍历: 先序,中序,后序: 二叉树的遍历有三种常见的方法, 最简单的实现就是递归调用, 另外就是飞递归的迭代调用, 最后还有O(1)空间的morris遍历: 二叉树的结构定义: struct ...
- [Leetcode] Binary tree level order traversal二叉树层次遍历
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...
- 算法与数据结构(三) 二叉树的遍历及其线索化(Swift版)
前面两篇博客介绍了线性表的顺序存储与链式存储以及对应的操作,并且还聊了栈与队列的相关内容.本篇博客我们就继续聊数据结构的相关东西,并且所涉及的相关Demo依然使用面向对象语言Swift来表示.本篇博客 ...
- C++版 - 剑指Offer 面试题39:二叉树的深度(高度)(二叉树深度优先遍历dfs的应用) 题解
剑指Offer 面试题39:二叉树的深度(高度) 题目:输入一棵二叉树的根结点,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度.例如:输入二叉树 ...
- python3实现二叉树的遍历与递归算法解析
1.二叉树的三种遍历方式 二叉树有三种遍历方式:先序遍历,中序遍历,后续遍历 即:先中后指的是访问根节点的顺序 eg:先序 根左右 中序 左根右 后序 左右根 遍历总体思路:将树分成最小 ...
- 二叉树的遍历--C#程序举例二叉树的遍历
二叉树的遍历--C#程序举例二叉树的遍历 关于二叉树的介绍笨男孩前面写过一篇博客 二叉树的简单介绍以及二叉树的存储结构 遍历方案 二叉树的遍历分为以下三种: 先序遍历:遍历顺序规则为[根左右] 中序遍 ...
- 数据结构与算法之PHP实现二叉树的遍历
一.二叉树的遍历 以某种特定顺序访问树中所有的节点称为树的遍历,遍历二叉树可分深度优先遍历和广度优先遍历. 深度优先遍历:对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次.可以细分 ...
随机推荐
- python获取https并且写文件日志
# -*- coding: utf-8 -*- import os import os.path import shutil import chardet import urllib.request ...
- Oracle 拆分列为多行 Splitting string into multiple rows in Oracle
=========================== The table is as follows: Name | Project | Error 108 test Err1, Err2, Err ...
- 使用Qt画出直方图和分位数图
https://blog.csdn.net/gudanai/article/details/72136420
- MySQL [Err] 1055--1064 - Expression #1 of ORDER BY clause is not in GROUP BY clause
1055错误: 方案1: 修改sql_mode的值 set sql_mode = '';set sql_mode = 'NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABL ...
- was unable to refresh its cache! status = Cannot execute request on any known server
出现这种错误是因为: Eureka服务注册中心也会将自己作为客户端来尝试注册它自己,所以我们需要禁用它的客户端注册行为. 在 yml中设置 eureka.client.register-with-eu ...
- Word 插入脚注、尾注与题注 -- 视频教程(5)
>> 视频教程链接:B站,速度快,清晰 未完 ...... 点击访问原文(进入后根据右侧标签,快速定位到本文)
- xe.10.2的下载路径
为了这个玩意,我折腾了一天,为了以后自己还用到 官网地址: http://altd.embarcadero.com/download/radstudio/10.2/delphicbuilder10_2 ...
- 二叉树根结点到任意结点的路径(C语言)
有一棵二叉树,如下图所示: 其中 # 表示空结点. 先序遍历:A B D E G C F 问题:怎么得到从根结点到任意结点的路径呢? 示例:输入 G,怎么得到从结点 A 到结点 G 的路径呢? 很明显 ...
- Cpp_Primer_4th_Edition-source-code
Cpp_Primer_4th_Edition-source-code 根据书上的去找,官网已经找不到了,毕竟第6版都已经出来了.不过有的朋友用的还是第4版,我的纸质书是第5版,pdf是第4版,都有在看 ...
- 高并发场景下System.currentTimeMillis()的性能问题的优化
高并发场景下System.currentTimeMillis()的性能问题的优化 package cn.ucaner.alpaca.common.util.key; import java.sql.T ...