数据结构课件第2章线性表.ppt
《数据结构课件第2章线性表.ppt》由会员分享,可在线阅读,更多相关《数据结构课件第2章线性表.ppt(114页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第二章第二章线性表线性表题目一:狐狸逮兔子实验题目一:狐狸逮兔子实验【问题描述】【问题描述】围绕着山顶有围绕着山顶有1010个圆形排列的洞,狐狸要吃兔个圆形排列的洞,狐狸要吃兔子,兔子说:子,兔子说:“可以,但必须找到我,我就藏可以,但必须找到我,我就藏身于这十个洞中,你先到号洞找,第二次隔身于这十个洞中,你先到号洞找,第二次隔个洞(即个洞(即3 3号洞)找,第三次隔个洞(即号洞)找,第三次隔个洞(即6 6号洞)找,以后如此类推,次数不限。号洞)找,以后如此类推,次数不限。”但狐但狐狸从早到晚进进出出了狸从早到晚进进出出了10001000次,仍没有找到兔次,仍没有找到兔子。问兔子究竟藏在哪个洞
2、里?子。问兔子究竟藏在哪个洞里?学习目标学习目标l掌掌握握线线性性表表的的顺顺序序存存储储结结构构及及具体操作实现;具体操作实现;l掌掌握握线线性性表表的的单单、双双向向链链接接存存储结构及具体操作实现;储结构及具体操作实现;l掌握算法时间复杂度分析。掌握算法时间复杂度分析。线性结构线性结构的定义:的定义:若若结结构构是是非非空空有有限限集集,则则有有且且仅仅有有一一个个开开始始结结点点和和一一个个终终端端结结点点,并并且且所所有有结结点点都都最最多多只只有有一一个个直直接接前前趋趋和和一一个个直直接接后后继继。可可表表示示为为:(a1,a2 ,an)特点:特点:1集合中必存在唯一的一个集合中
3、必存在唯一的一个“第一元素第一元素”;2集合中必存在唯一的一个集合中必存在唯一的一个“最后元素最后元素”;3除最后元素在外,均有除最后元素在外,均有 唯一的后继唯一的后继;4除第一元素之外,均有除第一元素之外,均有 唯一的前驱唯一的前驱。简言之,线性结构反映结点间的逻辑关简言之,线性结构反映结点间的逻辑关系是系是 的。的。线性结构包括:线性结构包括:线性表、堆栈、队列、线性表、堆栈、队列、字符串、数组字符串、数组等,其中最典型、最常等,其中最典型、最常用的是用的是-一对一一对一(1:1)线性表线性表2.1 线性表的类型定义线性表的类型定义2.3 线性表类型的实现线性表类型的实现 链式映象链式映
4、象2.2 线性表类型的实现线性表类型的实现 顺序映象顺序映象2.1线性表的类型定义线性表的类型定义2.1 线性表的基本概念线性表的基本概念、线性表线性表它是一种最简单的线性结构。是一它是一种最简单的线性结构。是一种可以在任意位置进行插入和删除数据种可以在任意位置进行插入和删除数据元素操作的,由元素操作的,由n(n0)个个相同类型相同类型数据数据元素元素a0,a1,an-1组成的线性结构。组成的线性结构。(a0,a1,ai-1,ai,ai1,,an-1)线性表的逻辑结构:线性表的逻辑结构:n=0时称为时称为数据元素数据元素线性起点线性起点ai的直接前趋的直接前趋ai的直接后继的直接后继下标,下标
5、,是元素的是元素的序号,表示元素序号,表示元素在表中的位置在表中的位置n为元素总为元素总个数,即表个数,即表长。长。n0n0空表空表线性终点线性终点 (A,B,C,D,Z)学号学号姓名姓名性别性别年龄年龄班级班级012003010622陈建武陈建武男男 192003级信息级信息0301班班012003010704赵玉凤赵玉凤女女 182003级信息级信息0302班班012003010813王王 泽泽男男 192003级信息级信息0303班班012003010906薛薛 荃荃男男 192003级信息级信息0304班班012003011018王 春男 19 192003级信息级信息0305班班:例
6、例2 分析学生情况登记表是什么结构。分析学生情况登记表是什么结构。分析分析:数据元素都是同类型(数据元素都是同类型(记录记录),元素间关系是线性的。),元素间关系是线性的。分析分析:数据元素都是同类型(数据元素都是同类型(字母字母),),元素间关系是线性的。元素间关系是线性的。注意:同一线性表中的元素必定具有相同特性注意:同一线性表中的元素必定具有相同特性!例例1 分析分析26 个英文字母组成的英文表是什么结构。个英文字母组成的英文表是什么结构。抽象数据类型线性表线性表的定义如下:ADT List 数据对象数据对象:D ai|ai ElemSet,i=1,2,.,n,n0 数据关系数据关系:R
7、1|ai-1,aiD,i=2,.,n 基本操作:基本操作:结构初始化操作结构初始化操作结构销毁操作结构销毁操作 引用型操作引用型操作 加工型操作加工型操作 ADT List InitList(&L)操作结果:操作结果:构造一个空的线性表L。初始化操作初始化操作 结构销毁操作结构销毁操作DestroyList(&L)初始条件:操作结果:线性表 L 已存在。销毁线性表 L。ListEmpty(L)ListLength(L)PriorElem(L,cur_e,&pre_e)NextElem(L,cur_e,&next_e)GetElem(L,i,&e)LocateElem(L,e,compare()
8、ListTraverse(L,visit()引用型操作引用型操作:ListEmpty(L)初始条件:操作结果:线性表L已存在。若L为空表,则返回TRUE,否则FALSE。(线性表判空)ListLength(L)初始条件:操作结果:线性表L已存在。返回L中元素个数。(求线性表的长度)PriorElem(L,cur_e,&pre_e)初始条件:操作结果:线性表L已存在。若cur_e是L的元素,但不是第一个,则用pre_e 返回它的前驱,否则操作失败,pre_e无定义。(求数据元素的前驱)NextElem(L,cur_e,&next_e)初始条件:操作结果:线性表L已存在。若cur_e是L的元素,但
9、不是最后一个,则用next_e返回它的后继,否则操作失败,next_e无定义。(求数据元素的后继)GetElem(L,i,&e)初始条件:操作结果:线性表L已存在,且 1iLengthList(L)。用 e 返回L中第 i 个元素的值。(求线性表中某个数据元素)LocateElem(L,e,compare()初始条件:操作结果:线性表L已存在,e为给定值,compare()是元素判定函数。返回L中第中第1个个与e满足满足关系compare()的元素的位序。若这样的元素不存在,则返回值为0。(定位函数)ListTraverse(L,visit()初始条件:操作结果:线性表L已存在,Visit()
10、为某个访问函数。依次依次对L的每个元素调用函数visit()。一旦visit()失败,则操作失败。(遍历线性表)加工型操作加工型操作 ClearList(&L)PutElem(&L,i,&e)ListInsert(&L,i,e)ListDelete(&L,i,&e)ClearList(&L)初始条件:操作结果:线性表L已存在。将L重置为空表。(线性表置空)PutElem(&L,i,&e)初始条件:操作结果:线性表L已存在,且 1iLengthList(L)。L中第i个元素赋值同e的值。(改变数据元素的值)ListInsert(&L,i,e)初始条件:操作结果:线性表L已存在,且 1iLengt
11、hList(L)+1。在L的第i个元素之前插入插入新的元素e,L的长度增1。(插入数据元素)ListDelete(&L,i,&e)初始条件:操作结果:线性表L已存在且非空,1iLengthList(L)。删除L的第i个元素,并用e返回其值,L的长度减1。(删除数据元素)利用上述定义的线性表线性表 可以实现其它更复杂的操作例例 2-2例例 2-3例例 2-1 假设:有两个集合集合 A 和和 B 分别用两个线性表线性表 LA 和和 LB 表示,即:线性表中的数据元素即为集合中的成员。现要求一个新的集合现要求一个新的集合AAB。例例 2-1 要求对线性表作如下操作:扩大线性表 LA,将存在于线性表存
12、在于线性表LB 中中而不存在于线性表不存在于线性表 LA 中中的数据元素插入到线性表插入到线性表 LA 中中去。上述问题可演绎为:1从线性表LB中依次察看每个数据元素;2依值在线性表LA中进行查访;3若不存在,则插入之。GetElem(LB,i)e LocateElem(LA,e,equal()ListInsert(LA,n+1,e)操作步骤:操作步骤:GetElem(Lb,i,e);/取取Lb中第中第i个数据元素赋给个数据元素赋给e if(!LocateElem(La,e,equal()ListInsert(La,+La_len,e);/La中不存在和中不存在和 e 相同的数据元素,则插入之
13、相同的数据元素,则插入之void union(List&La,List Lb)La_len=ListLength(La);/求线性表的长度求线性表的长度 Lb_len=ListLength(Lb);for(i=1;i=Lb_len;i+)/union 已知已知一个非纯集合非纯集合 B,试构造构造一个纯集合纯集合 A,使使 A中只包含中只包含 B 中所有值各中所有值各不相不相 同的数据元素同的数据元素。仍选用线性表线性表表示集合。例例 2-2集合集合 B集合集合 A从集合 B 取出物件放入集合 A要求集合A中同样物件不能有两件以上同样物件不能有两件以上因此,算法的策略应该和例算法的策略应该和例2
14、-1相同相同void union(List&La,List Lb)La_len=ListLength(La);Lb_len=ListLength(Lb);/union GetElem(Lb,i,e);/取取Lb中第中第 i 个数据元素赋给个数据元素赋给 e if(!LocateElem(La,e,equal()ListInsert(La,+La_len,e);/La中不存在和中不存在和 e 相同的数据元素,则插入之相同的数据元素,则插入之for(i=1;i=Lb_len;i+)InitList(La);/构造(空的)线性表LA若线性表中的数据元素相互之间可以比比较较,并且数据元素在线性表中依值
15、非递依值非递减或非递增有序减或非递增有序排列,即 aiai-1 或 aiai-1(i=2,3,n),则称该线性表为有序表有序表(Ordered List)(Ordered List)。试改变结构,以有序表有序表表示集合。例如例如:如果集合 B,(2,3,3,5,6,6,6,8,12)对集合 B 而言,值相同的数据元素必定相邻;值相同的数据元素必定相邻;如果构造一个纯集合 A,对集合 A 而言,数据元素依值从小至大的顺序插入。数据元素依值从小至大的顺序插入。因此,数据结构改变了,数据结构改变了,解决问题的策略也相应要改变。解决问题的策略也相应要改变。void purge(List&La,List
16、 Lb)InitList(LA);La_len=ListLength(La);Lb_len=ListLength(Lb);/求线性表的长度求线性表的长度 for(i=1;i=Lb_len;i+)/purge GetElem(Lb,i,e);/取取Lb中第中第i个数据元素赋给个数据元素赋给 eif(ListEmpty(La)|!equal(en,e)ListInsert(La,+La_len,e);en=e;/La中不存在和中不存在和 e 相同的数据元素,则插入之相同的数据元素,则插入之线性表的存储结构是指为它开辟的计算机线性表的存储结构是指为它开辟的计算机存储空间、存储空间的联系以及所采用的存
17、储空间、存储空间的联系以及所采用的程序实现方法。线性表的存储结构主要有程序实现方法。线性表的存储结构主要有如下两类:如下两类:(1)顺序存储结构顺序存储结构(2)(2)链式存储结构链式存储结构2.22.2 线性表类型的实现线性表类型的实现 顺序映像顺序映像 1、用一组地址连续地址连续的存储单元 依次存放依次存放线性表中的数据元素 (逻辑关系相邻(逻辑关系相邻,物理位置相邻。)物理位置相邻。)a1 a2 ai-1 ai an线性表的线性表的起始地址起始地址称作线性表的基地址基地址(1)逻辑上相邻的数据元素,其物理上也相邻;逻辑上相邻的数据元素,其物理上也相邻;(2)若已知表中首元素在存储器中的位
18、置,则其他若已知表中首元素在存储器中的位置,则其他元素存放位置亦可求出元素存放位置亦可求出。设首元素设首元素a0的存放地址为的存放地址为LOC(a0)(称称为首地址为首地址),),设每个元素占用存储空间(地址长度)为设每个元素占用存储空间(地址长度)为L字节,字节,则表中任一数据元素的则表中任一数据元素的存放地址存放地址为:为:LOC(ai+1)=LOC(ai)+L LOC(LOC(a ai i )=LOC()=LOC(a a0 0)+L*i)+L*i 对上述公式的解释如图所示对上述公式的解释如图所示2、线性表顺序存储特点:a a0 0a a1 1a ai ia ai+1i+1a an-1n-
19、1 地址地址 内容内容 元素在表中的位序元素在表中的位序0 0i i1 1n-1n-1空闲区空闲区i+1i+1Lb=LOC(a0)b+L Lb+i+iL Lb+(n-1)+(n-1)L Lb+(MaxSize-1)+(MaxSize-1)L LLOC(aLOC(ai i )=LOC(a)=LOC(a0 0)+L*i)+L*i3、线性表的顺序存储结构示意图、线性表的顺序存储结构示意图4、顺序映像的、顺序映像的 C 语言描述语言描述typedef struct SqList;/俗称 顺序表顺序表#define LIST_INIT_SIZE 80 /线性表存储空间的初始分配量#define LIST
20、INCREMENT 10 /线性表存储空间的分配增量ElemType*elem;/存储空间基址int length;/当前长度int listsize;/当前分配的存储容量 /(以sizeof(ElemType)为单位)5、线性表的基本操作在顺序表中的实现、线性表的基本操作在顺序表中的实现InitList(&L)/结构初始化结构初始化LocateElem(L,e,compare()/查找查找ListInsert(&L,i,e)/插入元素插入元素ListDelete(&L,i)/删除元素删除元素Status InitList_Sq(SqList&L)/构造一个空的线性表 /InitList_Sq
21、算法时间复杂度时间复杂度:O(1)L.elem=(ElemType*)malloc(LIST_ INIT_SIZE sizeof(ElemType);if(!L.elem)exit(OVERFLOW);L.length=0;L.listsize=LIST_INIT_SIZEreturn OK;定位:判断某个元素是否存在,存在给出其定位:判断某个元素是否存在,存在给出其位置,否则为位置,否则为0 023 75 41 38 54 62 17L.elemL.lengthL.listsizee=38pppppi 1 2 3 4 1 850p可见,基本操作是:将顺序表中的元素逐个和给定值 e 相比较。i
22、nt LocateElem_Sq(SqList L,ElemType e,Status(*compare)(ElemType,ElemType)/在顺序表中查询第一个满足判定条件的数据元素,在顺序表中查询第一个满足判定条件的数据元素,/若存在,则返回它的位序,否则返回若存在,则返回它的位序,否则返回 0 0/LocateElem_Sq O(ListLength(L)算法的算法的时间复杂度时间复杂度为:为:i=1;/i i 的初值为第的初值为第 1 1 元素的位序元素的位序p=L.elem;/p p 的初值为第的初值为第 1 1 元素的存储位置元素的存储位置while(i=L.length&!(
23、*compare)(*p+,e)+i;if(i=L.length)return i;else return 0;(*compare)(*p+,e)int LocateElem_Sq(SqList L,ElemType e,)p=L.elem;for(i=1;i=L.length;i+)if(*p+=e)return i;else return 0;/LocateElem_Sq时间复杂性:时间复杂性:(找到找到)最好最好 1 1次次 O(1)O(1)最坏最坏 n n次次 O(n)O(n)平均平均 n/2 n/2次次 O(n)O(n)(找不到找不到)最好最好 n+1 n+1次次 O(n)O(n)最
24、坏最坏 n+1 n+1次次 O(n)O(n)平均平均 n+1 n+1次次 O(n)O(n)线性表操作 ListInsert(&L,i,e)的实现:首先分析首先分析:插入元素时,线性表的逻辑结构逻辑结构发生什么变化发生什么变化?(a1,ai-1,ai,an)改变为 (a1,ai-1,e,ai,an)a1 a2 ai-1 ai ana1 a2 ai-1 ai ean,表的长度增加 Status ListInsert_Sq(SqList&L,int i,ElemType e)/在顺序表L的第 i 个元素之前插入新的元素e,/i 的合法范围为 1iL.length+1/ListInsert_Sq 算法
25、时间复杂度算法时间复杂度为为:O(ListLength(L)q=&(L.elemi-1);/q 指示插入位置for(p=&(L.elemL.length-1);p=q;-p)*(p+1)=*p;/插入位置及之后的元素右移元素右移*q=e;/插入e+L.length;/表长增1return OK;元素右移元素右移21 18 30 75 42 56 8721 18 30 75例如:ListInsert_Sq(L,5,66)L.length-10pppq87564266q=&(L.elemi-1);/q 指示插入位置for(p=&(L.elemL.length-1);p=q;-p)*(p+1)=*p
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 课件 线性
限制150内