数据结构实验指导书-013.docVIP

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构实验指导书-013

数据结构实验指导书 实验的目的、内容和要求 一、实验目的与要求 1. 通过上机实验加深对课程内容的理解,提高软件设计、编写及程序调试的能力。 2. 上机前要做好准备工作,包括程序框图、数据结构以及算法。 3. 按时实验。 4. 服从实验室老师的安排。 5. 独立实验,有问题可以讨论,但不得翻版。 6. 遵守实验室的各项纪律。 7. 要求所编的程序能正确运行,并提交实验报告。 二、实验内容 1. 线性表基本操作 :熟练掌握线性表的基本操作,及在两种存储结构上的实现。要求顺序表的数据域是整型数值,完成顺序表的初始化、插入、删除等操作,插入时不允许重复的值插入表中。要求单链表的数据域是字符串,完成单链表的初始化、插入、删除、逆向等操作。 2. 栈操作 :采用顺序存储结构,完成建栈、数据元素入栈与出栈、判断栈空、判断栈满等操作。 3. 二叉树操作 :采用二叉链表作为存储结构,完成二叉树的建立,先序、中序和后序以及按层次遍历的操作,求所有叶子及结点总数的操作等。 4. 图的遍历操作 :可采用邻接矩阵或邻接表作为存储结构,完成有向图和无向图的DFS和BFS操作。 5. 数据查找 :实现顺序查找、折半查找及二叉排序树上的查找算法,比较它们的查找速度。实验时所输入的数据可按有序和随机产生去组织。 6. 排序 :实现直接插入、冒泡、直接选择、快速、堆、归并等排序算法,比较各种排序算法的速度。 三、实验安排 第,,14,1周周: 说明用到的数据结构定义、主程序的流程及各程序模块之间的调用关系 实验1 线性表基本操作(4学时) 实验目的 ?掌握使用C++上机调试线性表的基本方法。 熟练掌握线性表的基本操作,及在两种存储结构上的实现。 ?熟悉顺序表的基本操作,完成顺序表的初始化、插入、删除等操作,插入时不允许重复的值插入表中。 熟悉对单链表的一些基本操作,完成单链表的初始化、插入、删除等操作。 实验内容 1.实现顺序表的定义和操作。该程序包括顺序表结构类型以及对顺序表操作的具体的函数定义。 /* 定义顺序表的最大长度为MAXSIZE */ #define MAXSIZE 50 /* 定义DataType为int类型 */ typedef int DataType; ? /* 顺序表的类型 */ typedef struct list { DataType vec[MAXSIZE]; int len; //顺序表的长度 } SeqList; ? 将此结构定义放在一个头文件sqlist.h中,并在头文件中给出顺序表的函数及常量的定义。 /* 初始化顺序表 */ SeqList* Create(); /* 清除顺序表 */ void Destroy(SeqList *L); /* 顺序表元素信息打印输出 */ void Print(SeqList *L); /* 判断顺序表是否为空 */ bool IsEmpty(SeqList *L); /* 判断顺序表是否为满 */ bool IsFull(SeqList *L); /* 向顺序表中添加数据 */ void Append(SeqList *L, DataType data); /*获取顺序表的长度 */ int GetLength(SeqList *L); /*删除顺序表中指定位置的元素 */ bool Delete(SeqList *L, int pos); /*在顺序表的指定位置中的添加元素 */ bool Insert(SeqList *L, int pos, DataType data); //*VS C++ 函数定义 void Create(const int iMax); void Destroy(); void Print(); bool IsEmpty(); bool IsFull(); void Append(const T data); int GetLength(); int GetMax(); bool Delete(const int pos); bool Insert(const int pos,const T data); 2.实现单链表的定义和操作。该程序包括单链表结构类型以及对单链表操作的具体的函数定义。 程序中的单链表(带头结点)结点为结构类型,结点值为整型。 /* 定义DataType为int类型 */ typedef int DataType; ? /* 单链表的结点类型 */ typede

文档评论(0)

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

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

1亿VIP精品文档

相关文档