【23王道数据结构】根据先序中序(中序后序)建立二叉树,并遍历

2024-03-09 15:30

本文主要是介绍【23王道数据结构】根据先序中序(中序后序)建立二叉树,并遍历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

思路
请添加图片描述
已知先序中序

TreeNode* ConstructTree(char pre[], int preStart, int preEnd, char in[], int inStart, int inEnd) {if (preStart > preEnd || inStart > inEnd) return NULL;TreeNode *root = (TreeNode *) malloc(sizeof (TreeNode));root->data = pre[preStart];//cout << "Constructor: root->data = " << root->data << endl;for (int i = inStart; i <= inEnd; i++) {//在中序序列中找到root的值if (in[i] == pre[preStart]) {//cout << "Constructor: i = " << i<< endl;root->lchild = ConstructTree(pre, preStart + 1, preStart + i - inStart,in, inStart, i - 1);root->rchild = ConstructTree(pre, preStart + i - inStart + 1, preEnd,in, i + 1, inEnd);}}return root;
}

已知后序中序

TreeNode* ConstructTree(char post[], int postStart, int postEnd, char in[], int inStart, int inEnd) {if (postStart > postEnd || inStart > inEnd) return NULL;TreeNode *root = (TreeNode*) malloc(sizeof (TreeNode));root->data = post[postEnd];for (int i = inStart; i <= inEnd; i++) {if (in[i] == post[postEnd]) {root->lchild = ConstructTree(post,postStart,postStart + i - inStart - 1,in, inStart, i - 1);root->rchild = ConstructTree(post, postStart + i - inStart,postEnd - 1,in, i + 1, inEnd);}}return root;
}

全部代码

//
// 根据前序中序构建二叉树
// Created by 48272 on 2022/4/25.
//
#include <iostream>
#include <cstdlib>
#include <vector>
#include <stack>
#include <queue>using namespace std;typedef struct TreeNode{char data;struct TreeNode *lchild, *rchild;
}TreeNode, *BiTree;/*** pre ABCDEFGHI* in BCAEDGHIF* @param pre* @param preStart* @param preEnd* @param in* @param inStart* @param inEnd* @return*/
TreeNode* ConstructTree(char pre[], int preStart, int preEnd, char in[], int inStart, int inEnd);/*** 中序遍历* @param root* @return*/
vector<char> inOrder(BiTree root);/*** 层次遍历* @param root* @return*/
vector<char> levelOrder(BiTree root);/*** 先序遍历* @param root* @return*/
vector<char> preOrder(BiTree root);int main() {char pre[9] = {'A','B','C','D','E','F','G','H','I'};char in[9] = {'B','C','A','E','D','G','H','F','I'};BiTree root = ConstructTree(pre, 0, 8, in, 0, 8);cout << "中序遍历:\n";vector<char> inorder =  inOrder(root);for (auto &item: inorder) cout << item;cout <<endl;cout << "层次遍历:\n";vector<char> levelorder = levelOrder(root);for (auto &item: levelorder) cout << item;cout << endl;cout << "先序遍历:\n";vector<char> preorder = preOrder(root);for (auto &item: preorder) cout << item;cout << endl;return 0;
}TreeNode* ConstructTree(char pre[], int preStart, int preEnd, char in[], int inStart, int inEnd) {if (preStart > preEnd || inStart > inEnd) return NULL;TreeNode *root = (TreeNode *) malloc(sizeof (TreeNode));root->data = pre[preStart];//cout << "Constructor: root->data = " << root->data << endl;for (int i = inStart; i <= inEnd; i++) {//在中序序列中找到root的值if (in[i] == pre[preStart]) {//cout << "Constructor: i = " << i<< endl;root->lchild = ConstructTree(pre, preStart + 1, preStart + i - inStart,in, inStart, i - 1);root->rchild = ConstructTree(pre, preStart + i - inStart + 1, preEnd,in, i + 1, inEnd);}}return root;
}vector<char> preOrder(BiTree root) {if (!root) return {};vector<char> preorder;TreeNode *p = root;stack<TreeNode*> s;while (p || !s.empty()) {// 有左孩子 一直向左走if (p) {preorder.push_back(p->data);s.push(p);p = p->lchild;}else { //否则取出栈顶,找右孩子p = s.top();s.pop();p = p->rchild;}}return preorder;
}vector<char> inOrder(BiTree root) {if (!root) return {};vector<char> inorder;TreeNode *p = root;stack<TreeNode*> s;while (p || !s.empty()) {// 有左孩子 一直向左走if (p) {s.push(p);p = p->lchild;}else { //否则取出栈顶,找右孩子p = s.top();s.pop();inorder.push_back(p->data);p = p->rchild;}}return inorder;
}vector<char> levelOrder(BiTree root) {if (!root) return {};vector<char> levelOrder;queue<TreeNode*> level;level.push(root);while (!level.empty()) {TreeNode *t = level.front();level.pop();levelOrder.push_back(t->data);if (t->lchild) level.push(t->lchild);if (t->rchild) level.push(t->rchild);}return levelOrder;
}

这篇关于【23王道数据结构】根据先序中序(中序后序)建立二叉树,并遍历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/791106

相关文章

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

建立升序链表

题目1181:遍历链表 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2744 解决:1186 题目描述: 建立一个升序链表并遍历输出。 输入: 输入的每个案例中第一行包括1个整数:n(1<=n<=1000),接下来的一行包括n个整数。 输出: 可能有多组测试数据,对于每组数据, 将n个整数建立升序链表,之后遍历链表并输出。 样例输

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

PHP实现二叉树遍历(非递归方式,栈模拟实现)

二叉树定义是这样的:一棵非空的二叉树由根结点及左、右子树这三个基本部分组成,根据节点的访问位置不同有三种遍历方式: ① NLR:前序遍历(PreorderTraversal亦称(先序遍历)) ——访问结点的操作发生在遍历其左右子树之前。 ② LNR:中序遍历(InorderTraversal) ——访问结点的操作发生在遍历其左右子树之中(间)。 ③ LRN:后序遍历(PostorderT

浙大数据结构:树的定义与操作

四种遍历 #include<iostream>#include<queue>using namespace std;typedef struct treenode *BinTree;typedef BinTree position;typedef int ElementType;struct treenode{ElementType data;BinTree left;BinTre

Python 内置的一些数据结构

文章目录 1. 列表 (List)2. 元组 (Tuple)3. 字典 (Dictionary)4. 集合 (Set)5. 字符串 (String) Python 提供了几种内置的数据结构来存储和操作数据,每种都有其独特的特点和用途。下面是一些常用的数据结构及其简要说明: 1. 列表 (List) 列表是一种可变的有序集合,可以存放任意类型的数据。列表中的元素可以通过索