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元?