- 1、本文档共17页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
数据结构上机;上机任务;一、熟悉实验环境;2.选择创建【Consoleapplication】——Go;3.在语言中选择C语言;4.填写项目名称和地址,点击Next?finished;二、上机内容
;任务一.实现顺序表的以下基本操作
1.voidInitList(SeqListL);
//创建一个顺序表
2.intInsert(SeqListL,ListDatax,inti);
//向顺序表中插入元素
3.intDelete(SeqListL,ListDatax);
//删除顺序表中的某个元素
4-1.intIsIn(constSeqListL,ListDatax);
//链表中是否存在x,如果存在则返回1,否则返回0
;任务一.实现顺序表的以下基本操作
4-2.intFind(constSeqListL,ListDatax);
//查询顺序表中值与x相同数据的序号,如果顺序表中不存在x,则返回-1.
4-3.intNext(constSeqListL,ListDatax);
//查询序列表中值为x的节点的后继,如果不存在则返回-1.
4-4.intPrevious(constSeqListL,ListDatax){
//查询序列表中值为x的节点的前驱,如果不存在则返回-1.;任务一.实现顺序表的以下基本操作
5.voidPrintList(constSeqListL);
//输出顺序表中的元素.要求相邻元素之间有空格,输出完最后一个元素后增加换行.
//例如[1,2,3]的输出结果为123\n
注意观察分析所写算法的复杂度。;任务二.顺序表拓展1
实现函数
intGetAverage(constSeqListL);
//返回顺序表所有元素的平均值.(结果取平均值的整数部分.);任务三.顺序表拓展2
实现函数
voidUnique(SeqListL);
/*
去除顺序表中所有的重复数据.
例如,如果顺序表L中的数据原来为
[1,2,3,4,2,3]
则Unique(L)后,结果为
[1,2,3,4]
*/;实现一个可变长的顺序表
我们可以注意到#defineLiseSize100限制了顺序表的最大长度。如果我们更改我们的定义方式
typedefintListData;
typedefstruct{
ListData*data;//存储空间基址
intlength; //当前元素个数
intListSize;
}SeqList;
则可以通过控制ListSize来控制数组的大小。当然由于分配的内存长度可能与ListSize不符,需要释放并重新分配空间。;实现一个可变长的顺序表
现在考虑以下算法:
假定最开始??,ListSize=1,每当SeqList中数据充满整个线性表时,我们将ListSize进行ListSize*=2操作,并重新分配内存空间,将数据复制到新的空间,再释放原来分配到的空间。每次数据满时都重复这种操作。
假定经过一系列Delete()操作,留下的数据已经不足ListSize的四分之一,此时我们将ListSize进行ListSize/=2操作,并重新分配内存空间,将数据复制到新的空间,再释放原来的空间。每次数据量不足ListSize的四分之一时都进行这种操作。;实现一个可变长的顺序表
这种数据结构被称作“动态数组”。C++的STL标准库中vector就是用这种方法实现的。
可以证明,这种方法会让每个元素分配的时间代价降低为O(1)。
附加题要求:重构Insert,Delete,unqiue方法,使得线性表不会收到最大长度的限制。
注意内存泄漏问题、程序正确性以及时间空间复杂度问题。
参考博客:/qqarticle/details作业命名方式;注意事项
您可能关注的文档
- (9)--第4章 树和二叉树-存储结构.ppt
- (9)--第七章第五节哈希表-哈希表的创建.pdf
- (9)--数据结构第七章课后作业.pdf
- (10)--2.如何成为一名合格的室内设计师.ppt
- (10)--05讲 数据恢复2192数据存储那些事儿.doc
- (10)--5.1油气管道安全管理及法规管理体系.ppt
- (10)--第4章 树和二叉树-定义和性质.ppt
- (10)--第七章第五节哈希表-哈希表的查找及性能分析.pdf
- (11)--2.室内空间分隔.ppt
- (11)--3.5第三章 能量食品营养学.ppt
- 2025内蒙古兴安盟科右前旗第二批公益性岗位开发附招聘笔试参考题库附答案解析.docx
- 2025陕西能源麟北发电有限公司社会招聘(8人)笔试参考题库附答案解析.docx
- 2025咸阳市秦都区郦城幼儿园招聘笔试参考题库附答案解析.docx
- 2025四川成都市第一人民医院引进高层次人才、急需人才招聘笔试参考题库附答案解析.docx
- 2025山东滨州市邹平市卫生事业单位招聘17人笔试参考题库附答案解析.docx
- 2025年西安建筑科技大学科研助理招聘(255人)考试备考试题及答案解析.docx
- 2025江苏盐城市射阳县城市照明服务有限公司聘5人笔试模拟试题及答案解析.docx
- 2025年马鞍山当涂县城区公办幼儿园选调幼儿教师26人笔试模拟试题及答案解析.docx
- 2025四川自贡市沿滩区招聘社区专职人员31人笔试参考题库附答案解析.docx
- 2025内蒙古兴安盟乌兰浩特市妇幼保健计划生育服务中心招聘控制数人员33人考试备考试题及答案解析.docx
文档评论(0)