Java二叉树怎么根据前序和中序推出后续
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,本篇内容介绍了"Java二叉树怎么根据前序和中序推出后续"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成
千家信息网最后更新 2025年12月03日Java二叉树怎么根据前序和中序推出后续
本篇内容介绍了"Java二叉树怎么根据前序和中序推出后续"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
根据前序跟中序 => 后序
#include#include #include using namespace std;struct BTreeNode{ int _value; BTreeNode*_left; BTreeNode*_right;};//解法一BTreeNode* RebuildCode(int * PreStart, int *PreEnd, int *InStart, int *InEnd){ BTreeNode *root = new BTreeNode(); //新建节点root保存前序第一个节点为根结点 root->_value = PreStart[0]; root-> _left = NULL; root->_right = NULL; if(InStart == InEnd && *InStart == *InEnd) { return root; } //据此节点找到中序遍历此节点的位置 int *rootIn = InStart; while(*PreStart != *rootIn) { rootIn++; } //左子树的长度 int leftlen = rootIn-InStart; //重建左子树 if(leftlen > 0) { root->_left = RebuildCode( PreStart+1, PreStart+leftlen, InStart,InStart+leftlen-1); } //重建右子树 if(InStart+leftlen < InEnd) { root->_right = RebuildCode( PreStart+leftlen+1, PreEnd,InStart+leftlen+1, InEnd); } return root;}BTreeNode* RebuildTree(int *PreOrder, int *InOrder, int len){ //首先判断边界条件 if(PreOrder == NULL || InOrder == NULL || len <= 0) { return NULL; } else { return RebuildCode(PreOrder, PreOrder+len-1, InOrder, InOrder+len-1); }}//后序遍历输出二叉树序列void PostOrder(BTreeNode *root){ if(root->_left != NULL) { PostOrder(root->_left); } if(root->_right != NULL) { PostOrder(root->_right); } if(root != NULL) { cout< _value<<" "; }}int main(){ int PreOrder[8] = {1,2,4,7,3,5,6,8}; int InOrder[8] = {4,7,2,1,5,3,8,6}; PostOrder(RebuildTree(PreOrder, InOrder, 8)); cout<
根据后序跟中序 =>前序#include#include #include using namespace std;struct BTreeNode{ int _value; BTreeNode*_left; BTreeNode*_right;};//解法一BTreeNode* RebuildCode(int * PostStart, int *PostEnd, int *InStart, int *InEnd){ BTreeNode *root = new BTreeNode(); //新建节点root保存前序第一个节点为根结点 root->_value = PostEnd[0]; root-> _left = NULL; root->_right = NULL; if(InStart == InEnd && *InStart == *InEnd) { return root; } //据此节点找到中序遍历此节点的位置 int *rootIn = InStart; while(*PostEnd != *rootIn) { rootIn++; } //左子树的长度 int leftlen = rootIn-InStart; //重建左子树 if(leftlen > 0) { root->_left = RebuildCode( PostStart, PostStart+leftlen-1, InStart,InStart+leftlen-1); } //重建右子树 if(InStart+leftlen < InEnd) { root->_right = RebuildCode( PostStart+leftlen, PostEnd-1, InStart+leftlen+1, InEnd); } return root;}BTreeNode* RebuildTree(int *PostOrder, int *InOrder, int len){ //首先判断边界条件 if(PostOrder == NULL || InOrder == NULL || len <= 0) { return NULL; } else { return RebuildCode(PostOrder, PostOrder+len-1, InOrder, InOrder+len-1); }}//后序遍历输出二叉树序列void PreOrder(BTreeNode *root){ if(root != NULL) { cout< _value<<" "; } if(root->_left != NULL) { PreOrder(root->_left); } if(root->_right != NULL) { PreOrder(root->_right); }}int main(){ int PostOrder[8] = {7,4,2,5,8,6,3,1}; int InOrder[8] = {4,7,2,1,5,3,8,6}; PreOrder(RebuildTree(PostOrder, InOrder, 8)); cout< "Java二叉树怎么根据前序和中序推出后续"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
节点
子树
位置
内容
据此
更多
条件
知识
结点
解法
边界
长度
输出
实用
学有所成
接下来
困境
实际
序列
情况
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络技术科普
同花顺软件开发氛围
数据库连接文件怎么查询
软件开发属不属于公司
高中信息技术数据库检索原理
天津大数据网络技术咨询商家
网络安全对联
pc服务器和pc机
欣邦网络技术有限公司
网络安全管理亮点
网络安全标牌手工
钦州网络安全宣传
网络安全热播剧
ssms创建数据库图书管理
阜阳设备维护管理软件开发平台
雨晴网络安全
小企业网络安全指南
csgo怎么重新刷新服务器
团课网络安全总结
江苏综合软件开发价格表格
数据库用的最多的两个字符字节
自己搭建游戏服务器玩国外
杨浦区微型软件开发服务商是什么
青岛东王子软件开发
软件开发论文评语
数据库中插入空值
服务器是个什么意思
数据库管理员有哪些证书
华为网络技术书电子版
泰兴进口网络技术大概费用