Java二叉树怎么根据前序和中序推出后续
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,本篇内容介绍了"Java二叉树怎么根据前序和中序推出后续"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成
千家信息网最后更新 2025年02月01日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安全错误
数据库的锁怎样保障安全
hypixel服务器
海信传媒网络技术有限公司
全球学术快报服务器没有响应
军地网络安全排查协议
软件开发及运维服务受控文件清单
网络安全比赛大全
我的世界手机钻石大陆服务器
服务器可以装ubuntu系统吗
h3c服务器镜像安装
ncbi提交数据库步骤
品质网络技术推广系统
照片 提取数据库
数据库索引的原则
服务器繁荣度
凤凰金融网络安全错误
复制传递和比较数据库
网络安全管理规定讨论
集结号服务器
数据库时间字段可以建索引吗
广东计算机网络技术中专学校
华为服务器管理口系统安装
抢红包软件开发多少
全球网络安全市值最高
涉疫系统网络安全等级保护工作
东北林业大学网络安全中心
网络安全比赛是比什么
内网网络安全现状自查
4月29首都网络安全日
湖南软件开发公司名录
jdbc连接数据库实现查询