- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
摘要
现代社会中广泛地存在着具有层次特征或是具有分支关系的对象,而对于解决这些复杂繁琐的数据,就需要我们用更简化、更直观的去表达出来,以便达到简单易懂的目的。一般的线性结构难以简单明了地实现此类操作,如操作系统的文件构成、人工智能和算法分析的模型表示以及数据库系统的信息组织形式等,用线性结构难以把其中的逻辑关系表达出来,必须借助于数和图这样的非线性结构,因此在以模拟客观世界问题,解决客观世界问题为主要任务的计算机领域中树型结构是信息的一种重要组织形式,树有着广泛应用。在树型结构的应用中又以二叉树最为常用。
二叉树是一种非常重要的非线性结构,所描述的数据有明显的层次关系,其中的每个元素只有一个前驱。二叉树是最为常用的数据结构,有着非常广泛的运用。二叉树的遍历方式有三种:先序遍历、中序遍历和后序遍历。先序遍历的顺序为:先访问根结点,先序遍历左子树,先序遍历右子树(根左右);中序遍历顺序为:中序遍历左子树,访问根结点,中序遍历右子树(左根右);后序遍历顺序为:后序遍历左子树,后序遍历右子树,访问根结点(左右根)。由先序遍历和中序遍历,由中序遍历和后序遍历序列可以唯一确定一棵二叉树。
该课设是对二叉树的各种功能的实现的编写,理解二叉树各种性质,掌握三种遍历二叉树的实现顺序和过程。
关键字:二叉树、遍历二叉树、递归、Microsoft Visual C++软件
1 问题概述
1.1 问题分析
所谓遍历是指沿着某条搜索路线,一次对树中每个结点均做一次且仅做一次访问。遍历是二叉树上最重要的运算之一,是二叉树上进行其他运算的基础。二叉树的遍历是通过编写程序来实现二叉树的先序、中序和后序遍历,统计二叉树的结点个数,求二叉树的深度和销毁二叉树。
1.2 可行性分析
此程序主要是根据给定二叉树的先序遍历结果,构造出二叉树并输出按中,后序遍历的结果,以及求二叉树的叶子个数等。其中二叉树的结点用字符表示。
1.先创建二叉树:按先序次序输入,构造二叉链表表示的二叉树。
2.设计算法:先序遍历、中序遍历、后序遍历。
基于二叉树的递归定义,得到遍历二叉树的操作定义。
(1)先序遍历二叉树的操作定义:
若二叉树为空,则空操作;否则
a.访问根结点;
b.先序遍历左子数;
c.先序遍历右子数。
(2)中序遍历二叉树的操作定义:
若二叉树为空,则空操作;否则
a.中序遍历左子树;
b.访问根结点;
c.中序遍历右子数。
(3)后序遍历二叉树的操作定义:
若二叉树为空,则空操作;否则
a.后序遍历左子数;
b.后序遍历右子数;
c.访问根结点。
3.再加入求二叉树的深度,叶子节点个数及二叉树的销毁等算法。
4.设计main()函数调用以上步骤实现相关功能
1.3 系统流程图
系统的流程图如图1.1所示。
图1.1 系统流程图
系统二叉链表模拟图如图1.2所示。
图1.2 二叉链表图
2 系统设计
2.1 逻辑设计
2.1.1. 二叉树结点数据类型定义
template?typename?T?struct?BiNode?
{?
BiNodeT*rchild,*lchild;//指向左孩子的指针
T?data;//结点数据信息?};
2.1.2. 二叉树数据类型定义
template?typename?T?class?BiTree?{?
template?typename?T?
friend?ostream??operator?(ostream?os?,BiTreeT?bt)? public:?
BiTree();//无参构造函数?
BiTree(int?m){};//有参空构造函数?
BiTree(T?ary[],int?num,T?none);//有参构造函数??
BiTree();//析构函数?
void?preorder();//递归前序遍历??
void?inorder();//递归中序遍历??
void?postorder();//递归后续遍历?
void?levelorder();//层序遍历?
int??count();//计算二叉树的结点数??
void?display(ostream?os);//打印二叉树,有层次??
void?LevelNum();//计算每一层结点数??
void?PreOrder();//非递归前序遍历??
void?PostOrder();//非递归后序遍历??
void?creat();//创建二叉树?
protected:?//以下函数供上面函数调用??//对应相同功能?
Voidcreat(BiNodeT*root);//创建??
void?release(BiNodeT
您可能关注的文档
最近下载
- 2007年考研英语一真题解析.pdf VIP
- 救护车司机培训计划.pptx VIP
- 人教版七年级上册数学第三章 一元二次方程练习题.docx VIP
- 20211121-华金证券-纺织服装行业周报:10月社零回升,消费市场回暖.pdf VIP
- 非均匀有理B样条:B样条曲面II及NURBS.pdf VIP
- 妇产科护理网络在线课程的教学设计与实践应用.pdf VIP
- 十年(2016-2025)高考化学真题分类汇编:专题40 化学反应原理综合题——反应热+速率平衡(原卷版).docx VIP
- 设备安装、维修合同模板7篇.docx VIP
- 广东六校2025届高三10月联考英语试题.pdf VIP
- 削坡减载施工方案.docx VIP
文档评论(0)