- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第二章 线性表 实用文案 - PAGE 16 标准文档 第二章 线性表 本章的重点:掌握顺序表和单链表上实现的各种基本算法及相关的时间性能分析; 难点:使用本章所学的基本知识设计有效算法解决与线性表相关的应用问题。 要求达到“识记”的内容:线性表的逻辑结构特征,线性表上定义的基本运算,并利用基本运算构造出较复杂的运算。 要求达到“综合应用”的内容:顺序表的含义及特点,顺序表上的插入、删除操作,解决简单应用问题。链表如何表示线性表中元素之间的逻辑关系;单链表、双链表、循环链表链接方式上的区别;单链表上实现的建表、查找、插入和删除等基本算法及其时间复杂度。循环链表上尾指针取代头指针的作用,以及单循环链表上的算法与单链表上相应算法的异同点。双链表的定义和相关算法。利用链表设计算法解决简单应用问题。 要求达到“领会”的内容:顺序表和链表的比较,以及如何选择其一作为其存储结构才能取得较优的时空性能。 线性结构的特点: 在数据元素的非空有限集中, ⑴ 存在唯一的一个被称做“第一个”的数据元素; ⑵ 存在唯一的一个被称做“最后一个”的数据元素; ⑶ 除第一个之外,集合中的每个数据元素均只有一个前驱; ⑷ 除最后一个之外,集合中每个数据元素均只有一个后继。 2.1线性表的逻辑结构 一、线性表的定义 线性表是最常用且最简单的一种数据结构。一个线性表是n个数据元素的有限序列。 数据元素可以是一个数、一个符号、也可以是一幅图、一页书或更复杂的信息。线性表例: 1、 1 2 3 4 5 6 7 2、 3、 学号 姓名 语文 数学 C语言 6201001 张三 85 54 92 6201002 李四 92 84 64 6201003 王五 87 74 73 6201004 ? ? ? ? ... ? ? ? ? 数据元素也可由若干个数据项组成(如上例3)。这时常把数据元素称为记录。含有大量记录的线性表又称文件。 线性表中的数据元素类型多种多样,但同一线性表中的元素必定具有相同特性,即属同一数据对象,相邻数据元素之间存在着序偶关系。 a1 ... ai-1 ai ai+1 ... an ai是ai+1的直接前驱元素,ai+1是ai的直接后继元素。 线性表中元素的个数n定义为线性表的长度,为0时称为空表。在非空表中的每个数据元素都有一个确定的位置。ai是第i个元素,把i称为数据元素ai在线性中的位序。 二、线性表的类型定义 ⒈ 抽象数据类型线性表的定义如下: ADT List{ 数据对象: D={ai| ai(-ElemSet,i=1,2,...,n,n=0} 数据关系: R1={ai-1,ai| ai-1,ai(- D,i=2,...,n} 基本操作: InitList(L) DestroyList(L) ClearList(L) ListEmpty(L) ListLength(L) GetElem(L,i,e) LocateElem(L,e,compare()) PriorElem(L,cur_e,pre_e) NextElem(L,cur_e,next_e) ListInsert(L,i,e) ListDelete(L,i,e) ListTraverse(L,visit()) }ADT List 2、部分操作的类C实现: InitList(L) { L.elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType)); if(!L.elem)exit(OVERFLOW); L.length=0; L.listsize=LIST_INIT_SIZE; return OK; }//InitList GetElem(L,i,e) { *e=L.lem[i] }//GetElem ListInsert(List L,int i,ElemType e) { if(i1||iL.length+1) return ERROR; q=(L.elem[i-1]); for(p=(L.elem[L.length-1]);p=q;--p) *(p+1)=*p; *q=e; ++L.length; return OK; }//ListInsert void union(List La,List Lb) //利用两个线性表LA和LB分别表示两个集合A和B,现要求一个新的集合A=A∪B。 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 void MergeList(Lis
您可能关注的文档
最近下载
- 派出所校园防欺凌方案.docx VIP
- 汽车钢板弹簧后悬设计答辩--公开课件设计.ppt VIP
- 义务教育版(2024)七年级全一册信息科技 第9课 数据传输有新意 教案.docx VIP
- 7氯丁橡胶总结.ppt VIP
- 华为HCIA-GaussDB GaussDB应用开发 H13-911考试题库-下(判断、填空题).docx VIP
- DB37T5072-2016山东建筑工程建筑结构施工技术资料-全套资料表格word.docx VIP
- DB37T5072-2016山东建筑工程建筑结构施工技术资料-全套资料表格word.docx VIP
- DB37T5072_2016山东建筑工程建筑结构施工技术资料_[全套]资料表格word.docx VIP
- 一年级拼音书写四线三格.docx VIP
- 军民航防相撞课件.pptx VIP
文档评论(0)