用顺序和二叉链表作存储结构实现二叉排序树.docVIP

用顺序和二叉链表作存储结构实现二叉排序树.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE PAGE 1 河南城建学院 课程设计报告书 专 业:计算机科学与技术 课程设计名称:用顺序和二叉链表作存储结构实现二叉排序树 题 目: 班 级: 学    号: 姓    名: 同 组 人 员: 指 导 老 师: 完 成 时 间: 摘要 数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和操作等的学科。本课程设中的二叉排序树,可以用顺序存储和链式存储两种算法计算。本课程设中的二叉排序树,一共要实现四项基本的功能。它们分别是二叉搜索树的创建、中序遍历、查找结点和删除结点。 关键词:二叉排序树;中序遍历;搜索结点;删除结点;C\C++ 目录 TOC \o 1-3 \h \z \u 目录 2 第一章 课程设计题目及要求 3 1.1 C语言简介 3 1.2 课程设计题目 3 1.3 课程设计要求 3 第二章 算法思想 4 2.1 二叉排序树的定义 4 2.2 二叉排序树的实现 4 2.2.1 建立二叉排序树 5 2.2.2 二叉排序树的中序遍历 5 2.2.3 二叉排序树中元素的查找 5 2.2.4 二叉排序树中元素的删除5 第三章 算法实现 7 3.1 程序设计思想 7 3.2 程序模块 7 3.3 流程图 10 3.4 源程序代码 11 第四章 测试与分析 17 4.1 程序调试 17 4.2 调试结果分析 19 总 结 20 心得体会 21 参考文献 22 第一章 课程设计题目及要求 1.1 C/ C ++语言简介 C语言是一种结构化语言。它层次清晰,便于按模块化方式组织程序,易于调试和维护。C语言的表现能力和处理能力极强。它不仅具有丰富的运算符和数据类型,便于实现各类复杂的数据结构。它还可以直接访问内存的物理地址,进行位(bit)一级的操作。由于C语言实现了对硬件的编程操作,因此C语言集高级语言和低级语言的功能于一体。既可用于系统软件的开发,也适合于应用软件的开发。C是C++的基础,C++语言和C语言在很多方面是兼容的,C++程序员可以利用C++与C的兼容性而直接并有效的使用大量现成的程序库,从而开发出更简洁更高效的系统。 1.2 课程设计题目 用顺序和二叉链表作存储结构实现二叉排序树: (1)以回车(\n)为输入结束标志,输入数列L,生成一棵二叉排序树T; (2)对二叉排序树T作中序遍历,输出结果; (3)输入元素x,查找二叉排序树T,若存在含x的结点,则删除该结点,并作中序遍历(执行操作2);否则输出信息“无x”。 1.3课程设计要求 在处理题目时,要求从分析题目的需求入手,按设计抽象数据类型、构思算法、通过设计实现抽象数据类型、编制上机程序和上机调试等若干步骤完成题目,最终写出完整的分析报告。对于稍复杂的程序设计,要充分利用模块化程序设计方法,自顶向下,逐步细化,在整体思路确定的情况下,考虑所需模块数,各模块完成功能以及模块之间的数据联系和调用关系。给出主要模块的算法描述,用流程图或伪代码表示。说明:在设计的过程中,步骤1步骤4往往是反复进行,在后续步骤中发现问题,往往需要从头重新分析、设计。 第二章 算法思想 2.1二叉排序树的定义 二叉排序树的定义:二叉排序树或者是一棵空树,?或者是一棵具有如下性质的二叉树: (1)每个结点都有一个作为搜索依据的关键码(key),所有结点的关键码互不相同; (2) 若它的左子树非空,则左子树上所有结点的值均小于根结点的值; (3) 若它的右子树非空,则右子树上所有结点的值均大于根结点的值; (4) 左、右子树本身又各是一棵二叉排序树 2.2二叉排序树的实现 2.2.1建立二叉排序树 建二叉树的结点至少应当包含三个域,分别存放结点的数据data,左子女结点指针leftChild和右子女结点指针rightChild。整个二叉树的链表要有一个表头指针,它指向二叉树的根结点,其作用是当作树的访问点 从空的二叉排序树开始,经过一系列的查找插入操作以后,生成了一棵二叉排序树。 根据二叉排序树的定义,建立一棵二叉排序树的过程是按照待排序序列元素的先后次序,不断动态生成二叉树的结点,逐个插入到二叉树中。若p为根结点指针,b为当前待插入元素,其过程可以描述为: 若为空树(p=nil),动态生成一个结点,其数据域为当前待插入元素b,左、右指针域为“空”,p指向该结点。 若非空树,比较b与根结点数据data(p) 如果bdata(p), 将b插入左子树中; 如果b≥data(p),将b插入右子树中; 左、右子树的插入方式与二叉排序树的插入方式相同

文档评论(0)

ligennv1314 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档