- 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章节 线性表_链表
CH2 线性表 2.1 线性表的逻辑结构 2.2 线性表的顺序存储及运算实现 2.3 线性表的链式存储和运算实现 2.4 线性表的两种存储结构的比较 2.5 线性表的应用举例 教学目标 线性表的逻辑结构特征;线性表上定义的基本运算,并利用基本运算构造出较复杂的运算。 掌握顺序表的含义及特点,顺序表上的插入、删除操作是及其平均时间性能分析,解决简单应用问题。 掌握链表如何表示线性表中元素之间的逻辑关系;单链表、双链表、循环链表链接方式上的区别;单链表上实现的建表、查找、插入和删除等基本算法及其时间复杂度。循环链表上尾指针取代头指针的作用,以及单循环链表上的算法与单链表上相应算法的异同点。双链表的定义和相关算法。利用链表设计算法解决简单应用问题。 领会顺序表和链表的比较,以及如何选择其一作为其存储结构才能取得较优的时空性能。 教学重点与难点 本章的重点是掌握顺序表和单链表上实现的各种基本算法及相关的时间性能分析; 难点是使用本章所学的基本知识设计有效算法解决与线性表相关的应用问题。 教学方法 课堂讲授 提问互动 实验 2.1 线性表的类型定义 定义: 线性表(linear list) ( a1,a2,… , an ) 其中: n :数据元素的个数或线性表的长度; ai : 是一个抽象的符号,它的数据类型设定为ElemType,表示某一种具体的已知数据类型(1≤i≤n) 。 非空线性表的特征(P18) 有且仅有一个开始结点(表头结点 head)a1,它没有直接前驱,只有一个直接后继; 有且仅有一个终端结点(表尾结点tail)an,它没有直接后继,只有一个直接前驱; 其它结点都有一个直接前驱和直接后继; 元素之间为一对一的线性关系。 线性表的抽象数据类型定义(P18 ) ADT List{ 数据对象:D={ai|ai∈ElemSet;1≤i≤n,n≥0;} 数据关系:R={ai,ai+1| ai, ai+1∈D,i=1,2,……,n-1} 基本操作: InitList(L) ListLength(L) GetElem(L,i,e) PriorElem(L,cur_e,pre_e) NextElem(L,cur_e,next_e) LocateElem(L,e,compare()) ListInsert(L,i,e) ListDelete(L,i,e) }ADT List 算法2.1(线性表的首尾合并) void union(List La,List Lb){ La_len=ListLength(La);Lb_len=ListLength(Lb) ; for(i=1;i=Lb_len;i++){ GetElem(Lb,i,e); if (!LocateElem(La,e,equal)) ListInsert(La,++La_len,e); } }//union 算法分析: 设LocateElem的执行时间与表长成正比, 即:算法的时间复杂度为:O(ListLength(La) * ListLength(Lb)) 算法2.2(有序线性表的合并) void MergeList(List La,List Lb,List Lc){ InitList(Lc); i=j=1;k=0; La_Len=ListLength(La);Lb_Len=ListLength(Lb); while ((i=La_Len)(j=Lb_Len) { GetElem(La,i,ai); GetElem(Lb,j,bj); if (ai=bj) {ListInsert(Lc,++k,ai); ++i;} else {ListInsert(Lc,++k,bj);++j; } } while (i=La_len) { GetElem(La,i++;ai); ListInsert(Lc,++k,ai);} while (j=Lb_len) { GetElem(Lb,j++;bj); ListInsert(Lc,++k,bj);} }//MergeList 2.2 线性表的顺序存储结构 一、特点 用一组地址连续的存储单元依次存放线性表中的元素; 以元
文档评论(0)