数据结构课程设计1详解.doc

  1. 1、本文档共19页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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 ;//前序遍历??

文档评论(0)

335415 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档