C++实现二叉树

代码如下:

#include<iostream>
#include <queue>
#include <stack>
using namespace std;class BinTree
{
private:class TreeNode{public:int data;TreeNode *left;TreeNode *right;TreeNode ():data(0),left(nullptr),right(nullptr){}TreeNode(int e):data(e),left(nullptr),right(nullptr){}};private:TreeNode *root;public:BinTree():root(nullptr){}void pre_in_buildTree(int *pre, int *in, int n){if (n <= 0){cout << "The tree is null" << endl;return;}root = pre_in_dfsTree(pre, in, 0, n - 1, 0, n - 1);}void in_post_buildTree(int *in, int *post, int n){if (n <= 0){cout << "The tree is null" << endl;return;}root = in_post_dfsTree(in, post, 0, n - 1, 0, n - 1);}void preOrder(){predfsTree(root);cout << endl;}void inOrder(){indfsTree(root);cout << endl;}void postOrder(){postdfsTree(root);cout << endl;}void levelOrder()//层次遍历{if (root == nullptr){cout << "The tree is null" << endl;return;}queue<TreeNode *> q;q.push(root);while (!q.empty()){TreeNode *t = q.front();cout << t->data << " ";q.pop();if (t->left) q.push(t->left);if (t->right) q.push(t->right);}cout << endl;}void preOrder_Stack()//先序遍历(非递归){TreeNode *p = root;stack<TreeNode *> s;while (p || !s.empty()){while (p){cout << p->data << " ";s.push(p);p = p->left;}if (!s.empty()){p = s.top();s.pop();p = p->right;}}cout << endl;}void inOrder_Stack()//中序遍历(非递归){TreeNode *p = root;stack<TreeNode *> s;while (p || !s.empty()){while (p){s.push(p);p = p->left;}if (!s.empty()){p = s.top();cout << p->data << " ";s.pop();p = p->right;}}cout << endl;}void postOrder_Stack()//后序遍历(非递归){stack<TreeNode *>s;s.push(root);while (!s.empty()){TreeNode *t = s.top();s.pop();if (t){s.push(t);s.push(nullptr);if (t->right) s.push(t->right);if (t->left) s.push(t->left);}else{t = s.top();s.pop();cout << t->data << " ";}}cout << endl;}private:TreeNode* pre_in_dfsTree(int *pre, int *in, int o1, int h1, int o2, int h2)//传入先序遍历和中序遍历构造一颗树{if (o1 > h1) return nullptr;int val = pre[o1];TreeNode *root = new TreeNode(val);if (o1 == h1) return root;int mid = 0;while (in[o2 + mid] != val) mid++;root->left = pre_in_dfsTree(pre, in,o1+1 ,o1+mid ,o2,o2+mid-1 );root->right = pre_in_dfsTree(pre, in,o1+mid+1 ,h1 , o2 + mid + 1, h2);return root;}TreeNode * in_post_dfsTree(int *in, int *post, int o1, int h1, int o2, int h2)//传入中序遍历和后序遍历构造一颗树{if (o1 > h1) return nullptr;int val = post[h2];TreeNode *root = new TreeNode(val);if (o1 == h1) return root;int mid = 0;while (in[o1 + mid] != val) mid++;root->left = in_post_dfsTree(in, post, o1, o1+mid-1, o2, o2+mid-1);root->right = in_post_dfsTree(in, post,o1+mid+1 ,h1, o2 + mid, h2-1);return root;}void predfsTree(TreeNode *root)//先序遍历{if (root == nullptr) return;cout << root->data << " ";predfsTree(root->left);predfsTree(root->right);}void indfsTree(TreeNode *root)//中序遍历{if (root == nullptr) return;indfsTree(root->left);cout << root->data << " ";indfsTree(root->right);}void postdfsTree(TreeNode *root)//后序遍历{if (root == nullptr) return;postdfsTree(root->left);postdfsTree(root->right);cout << root->data << " ";}};int main()
{BinTree t1;int pre[] = { 3,9,20,15,7 };int in[] = { 9,3,15,20,7 };int post[] = { 9,15,7,20,3 };t1.pre_in_buildTree(pre, in,5);BinTree t2;t2.in_post_buildTree(in, post, 5);t1.levelOrder();t2.levelOrder();t1.preOrder();t2.preOrder();t1.preOrder_Stack();t1.inOrder();t2.inOrder();t1.inOrder_Stack();t1.postOrder();t2.postOrder();t1.postOrder_Stack();return 0;
}

测试结果如下:
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308976.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySql :Could not create connection to database server.

错误&#xff1a; Exception in thread “main” org.apache.ibatis.exceptions.PersistenceException:Error querying database. Cause:com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Could not create connection to database server. The error …

Vue 3拖更,尤雨溪介绍最新进展

Vue.js 作者尤雨溪近日介绍了 Vue 3 的最新进展。尤雨溪表示&#xff0c;由于在 Vue 3 上花费的大部分时间都投入到了设计和构建稳定的内核上&#xff0c;不过要让整个框架处于"ready"状态&#xff0c;不仅仅是内核的问题&#xff0c;还需要有兼容版本的支持库 &…

Mysql@和@@符号的详细使用说明

一、概述 是用户变量&#xff0c;是系统变量。 二、使用语法及实践 用户自定义变量 1、用户定义变量语法 SET var_name expr [, var_name expr] 如&#xff1a;set t1 100; 2、获取用户定义变量值方式&#xff0c;如&#xff1a; select t1 from dual; 如下图 系统变…

探讨NET Core数据进行3DES加密或解密弱密钥问题

【导读】之前写过一篇《探讨.NET Core数据进行3DES加密和解密问题》&#xff0c;最近看到有人提出弱密钥问题&#xff0c;换个强密钥不就完了吗&#xff0c;猜测可能是与第三方对接导致很无奈不能更换密钥&#xff0c;所以产生本文解决.NET Core中3DES弱密钥问题&#xff0c;写…

C++实现表达式树

代码如下: #include <iostream> #include <string> #include <stack> #include <queue> using namespace std;class Tree { private:class Node{public:char val;Node * left;Node *right;Node(char val):val(val),left(nullptr),right(nullptr){}Nod…

redis大幅性能提升之使用管道(PipeLine)和批量(Batch)操作

前段时间在做用户画像的时候&#xff0c;遇到了这样的一个问题&#xff0c;记录某一个商品的用户购买群&#xff0c;刚好这种需求就可以用到Redis中的Set&#xff0c;key作为productID&#xff0c;value就是具体的customerid集合&#xff0c;后续的话&#xff0c;我就可以通过p…

IDEA如何在包下建立子包

idea如何在包下建立子包 第一次在包下建立子包时候出现了问题 在java > springmvc包下再new上一个package controller的时候就会出现这个样子 如何解决 在IDEA2019 中的Show Options Menu下有一个Compacket Middle Packages将它关闭即可 解决成功

.NET Core微服务开发选项

微服务开发的关注点有哪些&#xff1f;微服务构最终的目标是实现业务的价值&#xff0c;交付&#xff0c;为了让开发人员更加关注业务开发和交付&#xff0c;微服务需要一些比较底层的基础设置&#xff0c;我们也称为微服务公共关注点。配置管理&#xff1a;对微服务可变参数进…

gRPC真要取代WebApi了,你还学得过来吗?

今年1月份微软曾宣布要实验性的对.NET支持 gRPC-Web&#xff0c;然后在6月份已经正式发布了。这些天尝试了下&#xff0c;真的很强大&#xff0c;不负责任的预言下&#xff0c;RESTful的时代即将过去&#xff0c;而gRPC要成为革命者&#xff01;先别急眼&#xff0c;下面我来详…

Spring5 jar包下载

下载地址 https://repo.spring.io/simple/libs-release-local/org/springframework/spring/ Spring5最新版本的下载 选择最新版本5.2.3 下载前两项&#xff0c;解压放入文件夹中 项目中导包 ps&#xff1a;我使用的开发工具是idea 第一步&#xff1a;在file中选择project st…

优化 Azure 成本,实现财务目标

点击上方蓝字关注“汪宇杰博客”原文&#xff1a;Omar Khan General Manager, Microsoft Azure翻译&#xff1a;汪宇杰导语我们的许多客户都面临着如何满足关键 IT 项目的资金需求的困难决策。我们在此共同帮助您实现财务目标。确保 Azure 工作负载的成本得到优化有助于释放资金…

采用config方式灵活配置我们的Quarz.net中的Job,Trigger

经常在项目中遇到定时任务的时候&#xff0c;通常第一个想到的是Timer定时器&#xff0c;但是这玩意功能太弱鸡&#xff0c;实际上通常采用的是专业化的第三方调度框架&#xff0c;比如说Quartz&#xff0c;它具有功能强大和应用的灵活性&#xff0c;我想使用过的人都非常了解&…

对于任给的一张无向带权连通图,求出其最小生成树(C++)

对于任给的一张无向带权连通图&#xff0c;求出其最小生成树。 题目要求: (1)编程创建一幅图 (2)输出创建的图 (3)编写Prim算法代码&#xff0c;实现图的最小生成树求解&#xff0c;且输出最小生成树 (4)编写Kruskal算法代码&#xff0c;实现图的最小生成树求解&#xff0c;且…

使用.Net Core实现的一个图形验证码

SimpleCaptcha是一个使用简单&#xff0c;基于.Net Standard 2.0的图形验证码模块。它的灵感来源于Edi.Wang的这篇文章https://edi.wang/post/2018/10/13/generate-captcha-code-aspnet-core&#xff0c;我将其中生成验证码的代码抽取出来进行封装得到了这个模块。下面介绍一下…

Maven编译项目时报错:不再支持源选项 5。请使用 6 或更高版本。 不再支持目标选项 1.5。请使用 1.6 或更高版本。

在使用Maven编译项目时报错&#xff1a; 不再支持源选项 5。请使用 6 或更高版本。 不再支持目标选项 1.5。请使用 1.6 或更高版本。 在项目pom.xml文件中增加maven编译的jdk版本设置&#xff0c;maven.compiler.source和maven.compiler.target&#xff1a; <properties&…

ABP框架 v3.0 已发布!

我们很高兴地宣布,ABP框架和ABP商业版3.0版已经发布.与常规的2周发布一个版本不同的是, 这个版本用了4周的时间.关闭了119个issue,合并了89个pull request 和主框架仓库中的798次提交.由于这是一个主要版本,它也包括了一些重大更改.不要害怕,这些变化都容易对应,并且下面会详细…

C++实现dijkstra单源最短路径

代码如下: #include <iostream> using namespace std; const int N 30; typedef char ElemType; const double noEdge 99999;class Graph { private:double G[N][N];int vertexN, edgeN;double dist[N];bool vis[N];int path[N];int sv;ElemType data[N];int findMinD…

WPF 框架全构建环境虚拟机硬盘分享

现在 WPF 完全开源了&#xff0c;咱可以构建自己私有的版本。我分享一个虚拟机硬盘给你&#xff0c;只要你下载下来&#xff0c;通过 VMWare 导入&#xff0c;即可无需任何配置&#xff0c;拿到一个能构建 WPF 官方源代码的全构建环境。可以用来只做你的定制版的 WPF 框架现在 …

基于.NetCore3.1搭建项目系列 —— 使用Swagger做Api文档 (下篇)

前言回顾上一篇文章《使用Swagger做Api文档 》&#xff0c;文中介绍了在.net core 3.1中&#xff0c;利用Swagger轻量级框架&#xff0c;如何引入程序包&#xff0c;配置服务&#xff0c;注册中间件&#xff0c;一步一步的实现&#xff0c;最终实现生产自动生产API接口说明文档…