数据结构 第2章课程介绍.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构 学习目标 了解线性表的逻辑结构特性是数据元素之间存在着线性关系。在计算机中表示这种关系的两类不同的存储结构是顺序存储结构和链式存储结构。 熟练掌握这两类存储结构的描述方法以及线性表的基本操作在这两种存储结构上的实现。 能够从时间和空间复杂度的角度综合比较线性表两种存储结构的不同特点及其适用场合。 结合线性表类型的定义增强对抽象数据类型的理解。 1. 线性表(Linear List)定义 由n(n≧0)个数据元素(结点)a1,a2,…ai ,…an组成的有限序列。其中数据元素的个数n定义为表的长度。 当n=0时称为空表 常常将非空的线性表(n0)记作:(a1,a2,…an) 称i为ai 在线性表中的位序。 线性表是由数据元素组成的有限有序的序列。 有序:指每个元素有确定的位置。 长度:指线性表中当前存储元素的个数。 表头:指线性表开始的结点。 表尾:指线性表结束的结点。 (a1,a2,…an)这里的数据元素ai(1≦i≦n)只是一个抽象的符号,其具体含义在不同的情况下可以不同,可以是简单的数据类型、复合的数据类型、记录。 2. 线性表(线性结构)的逻辑特征 线性表的特征 有穷性:由有限个元素组成,元素个数n—表长度,n=0空表。 设线性表为 (a1,a2, . . . ,ai,. . . ,an), 称 i 为 ai 在线性表中的位序。 有序性:线性表元素之间存在序偶关系,1in时 ai的直接前驱是ai-1,a1无直接前驱 ai的直接后继是ai+1,an无直接后继 同一性:线性表属于同类数据元素组成,每一个对象都属于同一数据对象 3. 线性表的抽象数据类型定义 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) 操作结果:构造一个空的线性表L. DestoryList(L) 初始条件:线性表L已经存在。 操作结果:销毁一个线性表L. ClearList(L ) 初始条件:线性表L已经存在。 操作结果:将L重置为空表。 ListEmpty(L) //若L为空表返回TRUE否F. ListLength(L)//返回L中数据元素的个数 GetElem(L,i,e)//用e返回L中第i个数据元素的值. LocateElem(L,e,compare())//返回L中第一个与e满足关系compare()的数据元素的位序,若这样的数据元素不存在,则返回0. PriorElem(L,cur_e,pre_e) ())//若cur_e是L的数据元素,且不是第一个,则用pre_e返回它的前驱,否则操作失败, pre_e无定义。 NextElem(L,cur_e,next_e)//若cur_e是L的数据元素,且不是最后一个,则用next_e返回它的后继,否则操作失败,next_e无定义。 ListInsert(L,i,e)//在L的第i个位置之前插入新的元素e,L的长度加1. ListDelete(&L,i,e)//删除L的第i个数据元素,并用e返回其值,长度减1. ListTraverse(L,visit())//对每个数据元素调用函数visit(). 一旦vist()失败,则操作失败。  }ADT List 算法举例: 例2-1 假设有两个集合A和B分别用两个线性表LA和LB表示(即:线性表中的数据元素即为集合中的成员),现要求一个新的集合A=A∪B。要求对线性表作如下操作:扩大线性表LA,将存在于线性表LB中而不存在于线性表LA中的数据元素插入到线性表LA中去。(注:∪ ——并集,属于A或者属于B) 算法举例: 思路: 1.从线性表LB中依次取得每个数据元素; GetElem(LB, i)→e 2.依值在线性表LA中进行查访; LocateElem(LA, e, equal( ) ) 3. 若不存在,则插入之。 ListInsert(LA, n+1, e) 算法实现: void union(List La, List Lb) { // 将所有在线性表Lb中但不在La中的数据元素插入到La中 La_len = ListLength(La); Lb_len = ListLength(Lb); // 求线性表的长度 for (i = 1; i = Lb_len; i++) { GetElem(Lb, i, e); // 取Lb中第i个数据元素赋给e if(!LocateElem(La, e, equal( ))

文档评论(0)

武神赵子龙 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档