DS实验题 Order 已知父节点和中序遍历求前、后序
题目:
思路:
这题是比较典型的树的遍历问题,思路就是将中序遍历作为位置的判断依据,假设有个节点A和它的父亲Afa,那么如果A和Afa的顺序在中序遍历中是先A后Afa,则A是Afa的左儿子,否则是右儿子。
用for遍历一遍所有的节点,让每一个节点都连接到它的父亲,最后从根节点开始访问即可。
代码:
//
// main.cpp
// Tree
//
// Created by wasdns on 16/12/19.
// Copyright ? 2016年 wasdns. All rights reserved.
//
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
using namespace std;
struct Node
{
int num;
Node *lnext, *rnext;
};
int fa[10005]; //父亲
Node* node[100005]; //节点
int midorder[100005]; //中序
int preorder[100005]; //先序
int aftorder[100005]; //后序
int tot = 0;
/*
Ininode函数:初始化各个节点
*/
void Ininode(int n)
{
for (int i = 1; i <= n; i++)
{
Node *p = new Node;
p -> num = i;
p -> lnext = NULL;
p -> rnext = NULL;
node[i] = p;
}
}
/*
isleft函数:判断儿子是左儿子还是右儿子
*/
bool isleft(int n, int num, int f)
{
bool ans = true;
for (int i = 1; i <= n; i++)
{
if (midorder[i] == num || midorder[i] == f)
{
if (midorder[i] == f) {
ans = false;
}
break;
}
}
return ans;
}
/*
CreatTree:建树
*/
Node* CreatTree(int n)
{
int i;
int fanum;
for (i = 2; i <= n; i++)
{
fanum = fa[i];
if (isleft(n, i, fanum)) {
node[fanum] -> lnext = node[i];
}
else {
node[fanum] -> rnext = node[i];
}
}
return node[1];
}
/*
CalPreorder函数:计算先序
*/
void CalPreorder(Node *p)
{
if (p -> lnext == NULL && p -> rnext == NULL) {
preorder[tot++] = p -> num;
return ;
}
preorder[tot++] = p -> num;
if (p -> lnext != NULL) CalPreorder(p -> lnext);
if (p -> rnext != NULL) CalPreorder(p -> rnext);
}
/*
CalAftorder函数:计算后序
*/
void CalAftorder(Node *p)
{
if (p -> lnext == NULL && p -> rnext == NULL) {
aftorder[tot++] = p -> num;
return ;
}
if (p -> lnext != NULL) CalAftorder(p -> lnext);
if (p -> rnext != NULL) CalAftorder(p -> rnext);
aftorder[tot++] = p -> num;
}
/*
PrintTree函数:中序遍历(queue思想)输出树
*/
void PrintTree(Node *head)
{
queue<Node*> q;
q.push(head);
Node *p;
while (!q.empty())
{
p = q.front();
q.pop();
cout << p -> num << " ";
if (p -> lnext != NULL) {
q.push(p -> lnext);
}
if (p -> rnext != NULL) {
q.push(p -> rnext);
}
}
cout << endl;
}
/*
Print函数:输出结果
*/
void Print(int n)
{
int i;
for (i = 0; i < n; i++) {
cout << preorder[i] << " ";
}
cout << endl;
for (i = 0; i < n; i++) {
cout << aftorder[i] << " ";
}
cout << endl;
}
int main()
{
int n;
cin >> n;
int i;
for (i = 1; i <= n; i++) {
cin >> fa[i];
}
for (i = 1; i <= n; i++) {
cin >> midorder[i];
}
Ininode(n);
Node* head;
head = new Node;
head = CreatTree(n);
//PrintTree(head);
CalPreorder(head);
tot = 0;
CalAftorder(head);
Print(n);
return 0;
}
2016/12/19
DS实验题 Order 已知父节点和中序遍历求前、后序的更多相关文章
- DS实验题 order
算法与数据结构 实验题 6.4 order ★实验任务 给出一棵二叉树的中序遍历和每个节点的父节点,求这棵二叉树的先序和后序遍历. ★数据输入 输入第一行为一个正整数n表示二叉树的节点数目,节点编号从 ...
- DS实验题 融合软泥怪-2 Heap实现
题目和STL实现:DS实验题 融合软泥怪-1 用堆实现优先队列 引言和堆的介绍摘自:Priority Queue(Heaps)--优先队列(堆) 引言: 优先队列是一个至少能够提供插入(Insert) ...
- DS实验题 Old_Driver UnionFindSet结构 指针实现邻接表存储
题目见前文:DS实验题 Old_Driver UnionFindSet结构 这里使用邻接表存储敌人之间的关系,邻接表用指针实现: // // main.cpp // Old_Driver3 // // ...
- HDU1710---树(知前序遍历与中序遍历 求后序遍历)
知前序遍历与中序遍历 求后序遍历 #include<iostream> #include<cstring> #include<queue> #include< ...
- 数据结构实验之求二叉树后序遍历和层次遍历(SDUT 2137)
Problem Description 已知一棵二叉树的前序遍历和中序遍历,求二叉树的后序遍历和层序遍历. Input 输入数据有多组,第一行是一个整数t (t<1000),代表有t组测试数据. ...
- DS实验题 Dijkstra算法
参考:Dijkstra算法 数据结构来到了图论这一章节,网络中的路由算法基本都和图论相关.于是在拿到DS的实验题的时候,决定看下久负盛名的Dijkstra算法. Dijkstra的经典应用是开放最短路 ...
- DS实验题 sights
算法与数据结构实验题 6.3 sights ★实验任务 美丽的小风姑娘打算去旅游散心,她走进了一座山,发现这座山有 n 个景点, 由于山路难修,所以施工队只修了最少条的路,来保证 n 个景点联通,娇弱 ...
- DS实验题 PlayGame Kruskal(UnionFindSet)
题目: 思路: 有两种做法,一种是Prim算法,另外一种则是我所使用的Kruskal算法,Kruskal的算法实现可以参考:最小生成树-Prim算法和Kruskal算法,讲的已经是十分清楚了. 具体算 ...
- PAT A1020——已知后序中序遍历求层序遍历
1020 Tree Traversals Suppose that all the keys in a binary tree are distinct positive integers. Give ...
随机推荐
- http://www.roncoo.com/article/detail/124661
http://www.roncoo.com/article/detail/124661
- sprint3冲刺第一天
1.计划了sprint3要做的内容: 整合前台和后台,然后发布让用户使用,然后给我们反馈再进行改进 2.backlog表格: ID 任务 Est 做了什么 1 实现用户登录与权限判定 4 进行用户分类 ...
- Codeforces 629C Famil Door and Brackets(DP)
题目大概说给一个长m的括号序列s,要在其前面和后面添加括号使其变为合法的长度n的括号序列,p+s+q,问有几种方式.(合法的括号序列当且仅当左括号总数等于右括号总数且任何一个前缀左括号数大于等于右括号 ...
- RColorBrewer包---R语言的配色方案
// RColorBrewer包介绍 RColorBrewer包提供了3套很好的配色方案.用户只需要指定配色方案的名称,就可以用包中的brewer.pal()函数生成颜色.这3套配色方案包括: 连续型 ...
- Ignatius's puzzle
Ignatius's puzzle Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ...
- A hard puzzle
A hard puzzle Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- topcoder SRM 619 DIV2 GoodCompanyDivTwo
注意题目给的最后一句话,如果部门任何employee都做不同类型的工作,则这个部门是一个diverse,题目是计算department的diverse数 读起来感觉有点别扭,英语没学好的原因 int ...
- [WP8.1UI控件编程]Windows Phone自定义布局规则
3.2 自定义布局规则 上一节介绍了Windows Phone的系统布局面板和布局系统的相关原理,那么系统的布局面板并不一定会满足所有的你想要实现的布局规律,如果有一些特殊的布局规律,系统的布局面板是 ...
- 【BZOJ1051】1051: [HAOI2006]受欢迎的牛 tarjan求强连通分量+缩点
Description 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B受欢迎. 这种关系是具有传递性的,如果A认为B受欢迎,B认为C受欢迎,那么牛A也认 ...
- 'Could not load NIB in bundle: 'NSBundle xxx/storeFlix.app> ' with name 'UIViewController-w6Q-ra-j06' and directory 'StoreFlixIpad.storyboardc
1.此代码是从 git clone xxx 下载的. 2.使用 sourcetree 下载即可解决此问题.