数据结构课件第2章线性表A.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
上堂课要点回顾;数据结构课程的内容;近3周 上课 内容;第二章 线性表 学习指南;【重点和难点】   链表是本章的重点和难点。扎实的指针操作和内存动态分配的编程技术是学好本章的基本要求,分清链表中指针 p 和结点 *p 之间的对应关系,区分链表中的头结点、头指针和首元结点的不同所指以及循环链表、双向链表的特点等。 【知识点】   线性表、顺序表、链表 【学习指南】 本章建议完成的算法设计题为:2.11,2.21,2.19,2.22,2.24,2.27,2.28,2.38 ;线性结构的特点:;第二章 线性表; 线性表:由一组数据组成,线性表或者是一个空表,或者可以写成(a1,a2,…ai,…an),其中ai是取自某个集合S的元素。当1in时,数据元素ai-1称为数据元素ai的直接前驱,而称ai+1为ai的直接后继。线性表中数据元素的个数称为该线性表的长度。;(a1, a2, … ai-1,ai, ai+1 ,…, an) ;形式化定义: Linearlist = (D, R);线性表的主要操作;对线性表可进行如下基本运算: InitList(L):构造一个空的线性表L。 ListLength(L):返回L数据元素的个数。 GetElem(L,i,e):用e返回L中第i个数据元素的值。 ListInsert(L,i,e):在L中第i个位置前插入新的数据元素e,L的长度加1。 ListDelete(L,i,e):删去L中第i个元素,用e返回其值,L的长度减1。 PriorElem(L,cur_e,pre_e):用pre_e返回数据元素cur_e的前驱,如果存在的话。 NextElem(L,cur_e,next_e):用next_e返回数据元素cur_e的后继,如果存在的话。 LocateElem(L,e,compare()):返回L中第一个与e满足关系compare()的数据元素的位序。0表示这种元素不存在。 ;例1 分析26 个英文字母组成的英文表;例3、学生健康情况登记表如下:;例4、一副扑克的点数 (2,3,4,…,J,Q,K,A) ;从以上例子可看出线性表的逻辑特征是: 在非空的线性表,有且仅有一个开始结点a1,它没有直接前趋,而仅有一个直接后继a2; 有且仅有一个终端结点an,它没有直接后继,而仅有一个直接前趋a n-1; 其余的内部结点ai(2≦i≦n-1)都有且仅有一个直接前趋a i-1和一个直接后继a i+1。 ; 线性表是一种典型的线性结构。 数据的运算是定义在逻辑结构上的,而运算的具体实现则是在存储结构上进行的。 抽象数据类型的定义为:P19 ; 算法2.1 例2-1 利用两个线性表LA和LB分别表示两个集合A和B,现要求一个新的集合A=A∪B。 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) }// for }; 算法2.2 p21 例2-2 巳知线性表LA和线性表LB中的数据元素按值非递减有序排列,现要求将LA和LB归并为一个新的线性表LC,且LC中的元素仍按值非递减有序排列。 此问题的算法如下: ;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 ; while(I=la-len){ getelem((la,I++,ai);listinsert(lc,++k,ai); } //while 处理l

文档评论(0)

sanshengyuan + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档