C++基于先序、中序遍历结果重建二叉树的方法
发布时间 - 2026-01-11 01:02:50 点击率:次本文实例讲述了C++基于先序、中序遍历结果重建二叉树的方法。分享给大家供大家参考,具体如下:

题目:
输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
实现代码:
#include <iostream>
#include <vector>
#include <stack>
using namespace std;
struct TreeNode {
int val;
TreeNode *left;
TreeNode *right;
TreeNode(int x) : val(x), left(NULL), right(NULL) {}
};
//创建二叉树算法
TreeNode* reConstructBinaryTree(vector<int> pre, vector<int> mid)
{
int nodeSize = mid.size();
if (nodeSize == 0)
return NULL;
vector<int> leftPre, leftMid, rightPre, rightMid;
TreeNode* phead = new TreeNode(pre[0]); //第一个当是根节点
int rootPos = 0; //根节点在中序遍历中的位置
for (int i = 0; i < nodeSize; i++)
{
if (mid[i] == pre[0])
{
rootPos = i;
break;
}
}
for (int i = 0; i < nodeSize; i++)
{
if (i < rootPos)
{
leftMid.push_back(mid[i]);
leftPre.push_back(pre[i + 1]);
}
else if (i > rootPos)
{
rightMid.push_back(mid[i]);
rightPre.push_back(pre[i]);
}
}
phead->left = reConstructBinaryTree(leftPre, leftMid);
phead->right = reConstructBinaryTree(rightPre, rightMid);
return phead;
}
//打印后续遍历顺序
void printNodeValue(TreeNode* root)
{
if (!root){
return;
}
printNodeValue(root->left);
printNodeValue(root->right);
cout << root->val<< " ";
}
int main()
{
vector<int> preVec{ 1, 2, 4, 5, 3, 6 };
vector<int> midVec{ 4, 2, 5, 1, 6, 3 };
cout << "先序遍历序列为 1 2 4 5 3 6" << endl;
cout << "中序遍历序列为 4 2 5 1 6 3" << endl;
TreeNode* root = reConstructBinaryTree(preVec, midVec);
cout << "后续遍历序列为 ";
printNodeValue(root);
cout << endl;
system("pause");
}
/*
测试二叉树形状:
1
2 3
4 5 6
*/
运行结果:
先序遍历序列为 1 2 4 5 3 6 中序遍历序列为 4 2 5 1 6 3 后续遍历序列为 4 5 2 6 3 1 请按任意键继续. . .
希望本文所述对大家C++程序设计有所帮助。
# C++
# 先序
# 中序
# 遍历
# 重建
# 二叉树
# C++ 非递归实现二叉树的前中后序遍历
# C++树之遍历二叉树实例详解
# C++ 数据结构二叉树(前序/中序/后序递归、非递归遍历)
# C++ 遍历二叉树实例详解
# 一波二叉树遍历问题的C++解答实例分享
# C++非递归队列实现二叉树的广度优先遍历
# C++实现二叉树非递归遍历方法实例总结
# C++超详细实现二叉树的遍历
# 第一个
# 给大家
# 不含
# 请按
# 在中
# 中都
# 所述
# 程序设计
# 讲述了
# class
# brush
# cpp
# endl
# midVec
# pre
# gt
# vector
# stack
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】
详解Huffman编码算法之Java实现
微信小程序 五星评分(包括半颗星评分)实例代码
Laravel如何保护应用免受CSRF攻击?(原理和示例)
jQuery validate插件功能与用法详解
Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置
Android实现代码画虚线边框背景效果
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
如何为不同团队 ID 动态生成多个非值班状态按钮
如何快速选择适合个人网站的云服务器配置?
Laravel distinct去重查询_Laravel Eloquent去重方法
如何基于云服务器快速搭建网站及云盘系统?
JavaScript数据类型有哪些_如何准确判断一个变量的类型
Laravel如何创建自定义中间件?(Middleware代码示例)
如何在阿里云服务器自主搭建网站?
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
Python文件异常处理策略_健壮性说明【指导】
详解jQuery中基本的动画方法
如何快速搭建高效服务器建站系统?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
Laravel如何实现模型的全局作用域?(Global Scope示例)
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
EditPlus中的正则表达式 实战(4)
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
Angular 表单中正确绑定输入值以确保提交与验证正常工作
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】
大连 网站制作,大连天途有线官网?
电商网站制作价格怎么算,网上拍卖流程以及规则?
Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】
如何在香港免费服务器上快速搭建网站?
如何构建满足综合性能需求的优质建站方案?
Laravel定时任务怎么设置_Laravel Crontab调度器配置
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
如何用AI帮你把自己的生活经历写成一个有趣的故事?
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
打造顶配客厅影院,这份100寸电视推荐名单请查收
如何实现建站之星域名转发设置?
网站制作价目表怎么做,珍爱网婚介费用多少?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
Laravel如何使用withoutEvents方法临时禁用模型事件
悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音
如何正确下载安装西数主机建站助手?
EditPlus中的正则表达式实战(5)
香港服务器租用每月最低只需15元?

