- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
线性表的顺序储存结构和实现--实验2报告讲述
实验二
线
性
表
的
顺
序
存
储
结
构
实
现
指导老师:朱芳
学号班级姓名:张杭俊
【实验目的】
熟悉Visual C++工程项目的文件组织方式;
线性表中数据元素间的关系及其顺序存储结构方式的表示方法;
线性表的操作方法与接口函数的设计方法;
【实验原理】
顺序表程序实现方法:
声明线性表的数据类型;
一般在头文件中声明(该头文件中还应包括操作接口的声明);
告诉编译器该数据类型占内存空间的大小;
定义线性表类型的变量;
在函数中或实现代码中的定义;
告诉编译器为变量分配内存空间;
操作线性表类型变量;
操作变量中保存的数据;
【实验要求】
熟悉线性表的逻辑结构特点;
熟悉线性表常用操作特点;
理解以上给出的线性表顺序存储结构基本原理;
项目组织及文件命名要规范;
【实验内容】
本次文件提供的代码
ListInArray.h :
#includeiostream
using namespace std ;
#define LISTSIZE 100
typedef int DataType ;
typedef struct SqList
{
DataType items[LISTSIZE] ;
int length ;
}LIST ;
void InitList(LIST L) ;
int ListEmpty(LIST L) ;
int ListLengtn(LIST L) ;
int ListInsert(LIST L , int pos , DataType item) ;
int ListDelete(LIST L , int pos , DataType * item) ;
int Getelem(LIST L , int pos , DataType * item) ;
int Find(LIST L ,DataType item) ;
int TraverseList(LIST L) ;
listInArray.cpp :
#includelistinarray.h
void InitList(LIST L)
{
L.length = 0 ;
}
int ListEmpty(LIST L)
{
if(L.length = 0)
return 1 ;
else
return 0;
}
int ListLength(LIST L)
{
return L.length ;
}
int ListInsert(LIST L ,int pos ,DataType item)
{
int i ;
if(L.length = LISTSIZE)
{
cout 顺序表满,无法插入! endl ;
return 0 ;
}
if(pos = 0 || pos L.length + 1)
{ cout 插入位置无效! endl ;
return 0 ;
}
for(i = L.length - 1 ; i = pos - 1 ; i--)
{
L.items[i + 1] = L.items[i] ;
}
L.items[pos - 1] = item ;
L.length++ ;
return 1 ;
}
int ListDelete(LIST L ,int pos ,DataType *item)
{
int i ;
if(ListEmpty(L))
{
cout 顺序表为空表,无法删除! endl;
return 0 ;
}
if(pos 1 || pos L.length)
{
cout 删除位置无效! endl ;
return 0 ;
}
* item = L.items[pos - 1] ;
for(i = pos ; i L.length ; i++)
L.items[i - 1] = L.items[i] ;
L.length-- ;
return 1 ;
}
int GetElem(LIST L , int pos , DataType * item)
{
if(ListEmpty(L))
return 0 ;
if(pos = 0 || pos L.length)
{
cout 位置无效! endl ;
return 0 ;
}
* item = L.items[pos - 1] ;
return 1 ;
}
i
文档评论(0)