- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构——线性表(一) 授课教员:沈 颖、杨 胜 学科网站:1 线性表是一个数据元素的有序(次序)集 线性表的基本特征: 存在唯一的一个被称作“第一个”的数据元素 存在唯一的一个被称作“最后一个”的数据元素 除第一个外,集合中的每个数据元素均只有一个前驱 除最后一个外,集合中的每个数据元素均只有一个后继 线性表的顺序表示: 用一组地址连续的储存单元依次储存线性表的数据元素。 附:算法时间复杂度T(n) 设Pi是在第i个位置找到所需元素的概率,则在长度为n的线性表中进行逐个查询时,所需比较的次数的平均次数为: 附:算法时间复杂度T(n) 设Pi是在第i个元素之前插入一个元素的概率,则在长度为n的线性表中插入一个元素时,所需移动的元素次数的平均次数为: 附:算法评价 设Qi是删除第i个元素的概率,则在长度为n的线性表中删除一个元素所需移动的元素次数的平均次数为: 优点 逻辑相邻,物理相邻 可随机存取任一元素 存储空间使用紧凑 缺点 插入、删除操作需要移动大量的元素 预先分配空间需按最大空间分配,利用不充分 表容量难以扩充 思考 对一批编号连续的灯(n个)进行关闭操作,要求: A、1的倍数关闭,2的倍数打开; B、修改编号; C、重复操作A 请问,最后关闭的灯在原来序列中的编号是多少?算法复杂度为多少? 2.2.3 插入操作 InsertNode(T a , int i) 删除操作指假设顺序表中己有length(1≤ length≤maxsize)个数据元素,删除指定位置的数据元素 算法思路: 如果列表为空,或者不符合1≤i≤length,则提示没有要删除的元素,否则转入步骤2。 将第i+1到第length(共length-i)个数据元素依次前移 使顺序表的表长度length减1 2.2.4 删除操作 DeleteNode(int i) 如:(a1,…, ai-1, ai, ai+1, …, an) 改变为 (a1, …, ai-1, ai+1, …, an) ai+1 … an ai-1, ai, ai, ai+1 ai-1, ai+1 表的长度减少 a1 a2 … ai-1 ai ai+1 … an a1 a2 … ai-1 2.2.4 删除操作 DeleteNode(int i) a1 a2 ai ai+1 an a1 a2 ai+1 0 1 i-1 n-2 i n-1 an ai+2 Length-- 0 1 i-1 n-1 i n 数组下标 data[i-1] data[length-1] For( j=i; jlength; j++) data[j-1]=data[j]; 2.2.4 删除操作 DeleteNode(int i) public void DeleteNode(int i) { } For( j=i; jL.length; j++) data[j-1]=data[j]; // 被删除元素之后的元素左移 --L.length; //表长减1 return OK; 算法时间复杂度为: O( L.length) if ((i 1) || (i L.length)) return ERROR; //删除位置不合法 2.2.4 删除操作 DeleteNode(int i) 2.2.4 删除操作 DeleteNode(int i) e=Lb.GetNode(i); // 取Lb中第i个数据元素赋给e if (! La.SearchNode(e)) La.InsertNode(e , ++La_len); // La中不存在和 e 相同的数据元素,则插入之 void union(List La, List Lb) { La_len = La.GetLength(); // 求线性表的长度 Lb_len = Lb.GetLength(); for (i = 1; i = Lb_len; i++) { } } 算法回顾:线性表上的操作实例1 T = O(LA.length×LB.length) void MergeList(List La, List Lb, List Lc) { // 本算法将非递减的有序表 La 和 Lb 归并为 Lc } // merge_list while ((i = La_len) (j = Lb_len)) { // La 和 Lb 均不空 } whil
您可能关注的文档
最近下载
- 浅谈延安红色旅游发展问题及其对策 .docx VIP
- 毕业论文(基于JAVA的图书管理系统).doc VIP
- 2025-2030注塑机市场发展现状调查及供需格局分析预测研究报告.docx
- 2023年云南省中考化学试卷真题 (含答案,原卷).pdf
- (高清版)DB32∕T 4060-2021 建筑垃圾再生骨料路面基层应用技术标准.pdf VIP
- 标准图集-07FK02-防空地下室通风设备安装.pdf VIP
- 永大电梯Y15调试资料手顺及故障码.docx
- 第四版国际压力性损伤溃疡预防和治疗临床指南解读课件课件.pptx VIP
- 黔东南风电项目投资计划书.pdf
- 2025年云南省能源投资集团有限公司招聘笔试备考试题及答案解析.docx VIP
文档评论(0)