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