数据结构上机试验.PDF

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构上机试验

数据结构上机实验 本课程实验中已知的预定义常量和类型如下: #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEASIBLE -1 #define OVERFLOW -2 typedef int Status ; 实验一 顺序表(一) 一、 实验目的 掌握顺序表的定义、存储结构及其基本操作。 二、 实验内容 已知:线性表的动态分配顺序存储结构为 #define LIST_INIT_SIZE 100 #define LISTINCREMENT 10 typedef struct{ int *elem ; int length ; int listsize ; }SqList; 在主程序中调用如下函数 实现构造线性表,在线性表中插入数值,最后输出线性表。 1. 编写函数,Status InitList(SqList *L) 实现构造一个空的线性表,若构造成功则返回 OK,否则返 回ERROR 。 2. 编写函数,Status ListInsert(SqList *L , int i , int e) 实现在线性表 L 中第i 个位置之前插入新的数 据元素 e,L 的长度加 1。若插入成功返回OK,否则返回ERROR 。 (提示:i 的合法值为:i=1i=L—length+1 ) 3. 编写函数,void ListPrint (SqList *L )实现将线性表中的元素依次输出到屏幕上。 4 .编写函数,int Menu (),输出菜单项 请选择你要进行的操作(请输入 1-4 中的任一个数字): 输入 1 :InitList 2 :ListInsert 3 :ListPrint 4 :Exit 实验二 顺序表(二) 一、 实验目的 掌握顺序表的定义、存储结构及其基本操作。 二、 实验内容 在实验一的基础上,继续完成如下实验内容。 1.编写函数,Status ListDelete(Splist *L ,int i ,int *e),实现删除L 的第i 个数据元素,并用 e 返回 其值,L 的长度减 1。删除成功返回OK (1),否则返回ERROR (0 )。 (提示:i 的合法值为:i=1i=L—length ) 2.编写函数 Status GetElem (SqList *L,int i,int *e ),实现用 e 将线性表中第 i 个数据元素返回。若 返回成功则函数返回 OK (1),否则返回ERROR (0 )。(提示:i 的合法值为:i=1i=L—length ) 3 .编写函数,int Menu (),输出菜单项 请选择你要进行的操作(请输入 1-6 中的任一个数字): 输入 1: InitList 2 : ListInsert 3 : ListPrint 4 : ListDelete 5: GetElem 6: Exit 实验三 顺序表(三) 一、实验目的 掌握顺序表的定义、存储结构及其基本操作。 二、实验内容 在实验二的基础上,继续完成如下实验内容。 在 main 函数中分别调用 initList 和 ListInsert 函数生成 2 个按值非递减有序的线性表La 和 Lb ,然后再 调用 MergeList 函数完成将LA 和 LB 归并为一个新的线性表 LC ,且 LC 中的数据元素仍按值非递减有序排 列。最后输出LC 。 1.编写函数,void

文档评论(0)

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

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

1亿VIP精品文档

相关文档