- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
顺序表作例子
实验报告
实验项目:顺序表基本操作
年级:10级 专业:信息102
本组学生:崔瑞雪、历红影、梁静琦、王芳
实验日期:2012年3月26日
实验目的
1、熟悉C语言的上机环境,掌握C语言的基本结构。
2、学会定义线性表的顺序存储结构,并加深对顺序表相关基本操作的了解。
3、用C语言实现顺序表的基本操作。
实验问题描述
该程序的功能是对元素类型为整型的顺序表进行一些操作。该程序包括一个头文件,用来存储定义的顺序表结构类型以及对顺序表进行各种操作的函数声明;第二个为顺序表操作的实现文件,用来存储每一种顺序表操作的具体的函数定义以及主函数。
实现部分
/* 定义ElemType为int类型 */
typedef int ElemType;
/*顺序表存储空间的总分配量*/
#define MAXSIZE 100
#define FALSE 0
#define TRUE 1
/* 顺序存储类型 */
typedef struct
{ElemType data[MAXSIZE]; /*存放线性表的数组*/
int last; /* last是顺序表的长度*/
}SeqList;
/* 初始化顺序表 */
SeqList SeqListInit( )
{
}
/* 清空顺序表 */
SeqList ListClear(SeqList L)
{
}
/* 求顺序表长度 */
int ListLast(SeqList L)
{
}
/* 检查顺序表是否为空 */
int ListEmpty(SeqList L)
{
}
/*检查顺序表是否为满 */
int ListFull(SeqList L)
{
}
/* 遍历顺序表 */
void ListTraverse(SeqList L)
{
}
/* 从顺序表中查找元素 */
ElemType ListGet(SeqList L ,int i)
{
}
/* 从顺序表中查找与给定元素值相同的元素在顺序表中的位置 */
int ListLocate(SeqList L, ElemType x)
{
}
/* 向顺序表中插入元素 */
SeqList ListInsert(SeqList L,int i,ElemType x)
{
}
/* 从顺序表中删除元素 */
SeqList ListDelete(SeqList L,int i)
{
}
实验步骤
1、实验问题分析
运用C语言实现顺序表的相关操作,将会用到for循环,if、else语句,指针,宏定义。
2、功能(函数)设计,函数原型,完成的工作,功能。
/* 初始化顺序表 */
SeqList SeqListInit( )
{
SeqList L;
L.last=0;
return L;
}
/* 清空顺序表 */
SeqList ListClear(SeqList L)
{
if(L.last!=0)
L.last=0;
return L;
}
/* 求顺序表长度 */
int ListLast(SeqList L)
{
return L.last;
}
/* 检查顺序表是否为空 */
int ListEmpty(SeqList L)
{
if(L.last==0)
return TRUE;
else
return FALSE;
}
/*检查顺序表是否为满 */
int ListFull(SeqList L)
{
if(L.last==MAXSIZE)
return TRUE;
else
return FALSE;
}
/* 遍历顺序表 */
void ListTraverse(SeqList L)
{
int i;
ElemType *p;
if(ListEmpty(L)==1)
{
printf(顺序表是空表\n);
exit(0);
}
p=L.data;
for(i=0;iL.last;i++)
printf(%d,,p[i]);
}
/* 从顺序表中查找元素 */
ElemType ListGet(SeqList L ,int i)
{
if(ListEmpty(L)==1)
{
printf(顺序表是空表\n);
exit(0);
}
else
return L.data[i-1];
}
/* 从顺序表中查找与给定元素值相同的元素在顺序表中的位置 */
int ListLocate(SeqList L, ElemType x)
{
int j;
for(j=0;jL.last;j++)
if(L.data[j]==x)
retur
文档评论(0)