- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
浙江大学城市学院实验报告
课程名称 数据结构基础
实验项目名称 实验四 线性表的顺序表示和实现
学生姓名 吴奇 专业班级 信管1204 学号
实验成绩 指导老师(签名 ) 日期
实验目的和要求
1、掌握线性表的顺序存储结构;
2、掌握线性表的动态分配顺序存储结构及基本操作的实现函数;
3、进一步熟悉数据结构及算法的程序实现的基本方法。
实验内容
1、编写应用程序,实现可以在顺序表中插入任意给定数据类型数据并求和的功能。要求把顺序表的结构定义与基本操作实现函数存放在头文件SeqList.h中,主函数存放在主文件test2_1.cpp中,在主函数中定义顺序表并通过调用基本操作函数来实现对该顺序表插入若干个整数类型的数据,然后求和输出。要求使用动态存储分配的方式申请数组空间。
2、选做:编写函数bool DeleteElem(SeqList L, int min, int max), 实现从顺序表中删除其值在给定值min和max之间(min max)的所有元素,要求把该函数添加到头文件SeqList.h中,并在主文件test2_1.cpp中添加相应语句进行测试。、、report4.doc 、源程序文件test2_1.cpp及SeqList.h到Ftp服务器上自己的文件夹下。
三. 函数的功能说明及算法思路
struct List{ //定义线性表的结构体
elemtype *list;
int size;
int maxsize;
};
void initlist(List L){ //初始化线性表L
L.maxsize=10; //线性表的最大长度定位10
L.list=new elemtype[L.maxsize]; //动态申请线性表的储存空间
if(L.list==NULL){ //判断线性表指向是否为空
cout动态分配空间已用完,按任意键退出程序!endl;
getchar();
exit(0);
}
L.size=0; //线性表的初始长度为0
}
bool insertlist(List L,elemtype item, int pos){ //线性表的元素插入
if(L.size==L.maxsize){ //判断线性表的储存空间是否满
/*L.list=new elemtype[2*L.maxsize];*/
int k=sizeof(elemtype); //计算elemtype类型的字符长度
L.list=(elemtype*)realloc(L.list,2*L.maxsize*k);//动态申请空间
if(L.list==NULL){
cout动态可分配的储存空间用完,按任意键退出!!endl;
getchar();
exit(0);
}
L.maxsize=2*L.maxsize; //将线性表的长度扩大2倍
}
L.list[pos-1]=item; //将输入的元素储存到线性表中
L.size++;
return true;
}
void travellist(List L){ //遍历线性表的元素
int i;
cout线性表中的数字为:endl;
for(i=0;iL.size;i++){ //输出线性表中的所有元素
coutL.list[i] ;
}
coutendl;
}
int lengthlist(List L){ //计算线性表的长度
return L.size;
}
int getlist(List L,int pos){ //获取线性表中位于pos位置的元素
if(pos1||posL.size){
cout输入有误,按任意键退出程序!!endl;
getchar();
exit(0);
}
return L.list[pos-1]; //返回需要获取的元素
}
void clearlist(List L){ //清空线性表L
if(L
您可能关注的文档
最近下载
- 2024年高中数学同步高分突破讲义(人教A版2019)1.1空间向量及其运算-(选择性必修第一册)(学生版+解析).docx VIP
- 青岛版四年级上册科学新教材全部实验.pdf VIP
- 儿童财商启蒙课课件.pptx
- 2025年职业技能鉴定考试(造林更新工)历年参考题库含答案详解(5卷).docx VIP
- 2025入团考试100题题库(含答案).docx VIP
- 2024年山西对口升学英语考试真题(含答案).pdf VIP
- 新北师大版三年级上册数学(全册)同步随堂练习一课一练.pdf VIP
- 《玫瑰少年》经典音乐曲谱.pdf VIP
- 军队文职思维导图:公共科目基础知识-非法.pdf VIP
- 第4课 用联系的观点看问题-【中职专用】2024年中职思想政治《哲学与人生》金牌课件(高教版2023·基础模块).pptx VIP
文档评论(0)