- 1、本文档共19页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话: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? ?struct?BiNode BiNode *rchild,*lchild;//指向左孩子的指针
T?data;//结点数据信息? ;
2.1.2. 二叉树数据类型定义
template? ?class?BiTree template friend?ostream??operator? ostream?os?,BiTree ?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 BiNode *root ;//创建??
void?release BiNode *?root ;//删除?
BiNode ?*?Build T?ary[],int?num,T?none,int?idx ;//用数组创建二叉树??
void?PreOrder BiNode *?root ;//前序遍历??
您可能关注的文档
- 诗词写作入门4详解.ppt
- 诗歌表达技巧joy7新详解.ppt
- 诗歌鉴赏分类介绍详解.ppt
- 狮子和鹿课件详解.ppt
- 施工测量工作管理办法详解.doc
- 施工工艺及标准详解.docx
- 施工管理用表详解.doc
- 施工机械专项方案详解.doc
- 蔬菜深加工改扩建项目可行性研究报告详解.ppt
- 蔬菜物流体系中的价格构成及利润分配研究最新详解.ppt
- 《商业银行信用卡业务风险管理与金融风险管理实践案例分析》教学研究课题报告.docx
- 《区块链技术在电子政务中的数据溯源与可信审计机制研究》教学研究课题报告.docx
- 区域在线教育质量监管中的人工智能技术辅助教学效果分析教学研究课题报告.docx
- 2025年人工智能伦理标准制定与人工智能伦理委员会构建.docx
- 恶性积液的诊治与腔内化疗.pptx
- 《基于“双证书”制度的职业院校课程体系改革与创新》教学研究课题报告.docx
- 《城市声环境质量评价与噪声污染防治规划的法律法规体系构建研究》教学研究课题报告.docx
- 2025年产业转移园区社会稳定风险评估与风险评估政策法规研究报告.docx
- 2025年产业转移园区建设社会稳定风险评估报告:社会稳定与经济发展协调.docx
- 2025年产业转移园区建设社会稳定性评估与区域经济发展模式.docx
文档评论(0)