ds200902-线性表.ppt
《ds200902-线性表.ppt》由会员分享,可在线阅读,更多相关《ds200902-线性表.ppt(77页珍藏版)》请在咨信网上搜索。
1、数据结构数据结构北京化工大学北京化工大学信息科学与技术学院计算机系信息科学与技术学院计算机系史晟辉史晟辉n n线性表线性表n n顺序表顺序表 n n链表链表n n顺序表与链表的比较顺序表与链表的比较第二章第二章 线性表线性表5/25/20242北京化工大学信息学院 数据结构线性表线性表(Linear List)n n线性表的定义和特点线性表的定义和特点uu 定义定义 n n(0 0)个数据元素的有限序列,记作个数据元素的有限序列,记作个数据元素的有限序列,记作个数据元素的有限序列,记作 (a1,a2,ana1,a2,an)aiai 是表中数据元素,是表中数据元素,是表中数据元素,是表中数据元素
2、,n n 是表长度。是表长度。是表长度。是表长度。vv除第一个元素外,其他每一个元素有一个且仅有一除第一个元素外,其他每一个元素有一个且仅有一除第一个元素外,其他每一个元素有一个且仅有一除第一个元素外,其他每一个元素有一个且仅有一个个个个直接前驱直接前驱直接前驱直接前驱。vv除最后一个元素外,其他每一个元素有一个且仅有除最后一个元素外,其他每一个元素有一个且仅有除最后一个元素外,其他每一个元素有一个且仅有除最后一个元素外,其他每一个元素有一个且仅有一个一个一个一个直接后继直接后继直接后继直接后继。uu 特点特点 5/25/20243北京化工大学信息学院 数据结构顺序表顺序表(Sequentia
3、l List)n n顺序表的定义顺序表的定义顺序表的定义顺序表的定义n n顺序表的特点顺序表的特点顺序表的特点顺序表的特点n n顺序表的连续存储方式顺序表的连续存储方式顺序表的连续存储方式顺序表的连续存储方式n n顺序表顺序表顺序表顺序表(SeqListSeqList)的定义的定义的定义的定义n n顺序表顺序表顺序表顺序表(SeqListSeqList)的的的的操作操作操作操作n n顺序表的应用顺序表的应用顺序表的应用顺序表的应用数据对象数据对象数据对象数据对象逻辑关系逻辑关系逻辑关系逻辑关系存储关系存储关系存储关系存储关系操作操作操作操作5/25/20244北京化工大学信息学院 数据结构顺序
4、表顺序表(Sequential List)n n顺序表的定义和特点顺序表的定义和特点uu 定义定义 将线性表中的元素相继存放在一将线性表中的元素相继存放在一个连续的存储空间中。个连续的存储空间中。uu 可利用一维数组描述存储结构可利用一维数组描述存储结构uu 特点特点 线性表的顺序存储方式线性表的顺序存储方式uu 遍历遍历 顺序访问顺序访问,可以随机存取可以随机存取 25 34 57 16 48 09 0 1 2 3 4 5 0 1 2 3 4 5 data5/25/20245北京化工大学信息学院 数据结构顺序表的连续存储方式顺序表的连续存储方式35 27 49 18 60 54 77 83
5、41 020 1 2 3 4 5 6 7 8 9l l l l l l l l l l LOC(i)=LOC(i-1)+l=a+i*l,i 0 a,i=0 a+i*la5/25/20246北京化工大学信息学院 数据结构顺序表顺序表(SeqList)的定义的定义#define ListSize 100 /最大允许长度最大允许长度typedef int ListData;typedef struct ListData *data;/存储数组存储数组 int length;/当前元素个数当前元素个数 SeqList;5/25/20247北京化工大学信息学院 数据结构顺序表的操作顺序表的操作n n建立
6、空的顺序表建立空的顺序表建立空的顺序表建立空的顺序表n n求表的长度求表的长度求表的长度求表的长度n n按位置查找按位置查找按位置查找按位置查找n n按值查找按值查找按值查找按值查找n n顺序表的插入顺序表的插入顺序表的插入顺序表的插入n n顺序表的删除顺序表的删除顺序表的删除顺序表的删除5/25/20248北京化工大学信息学院 数据结构建立空的顺序表建立空的顺序表 voidvoid InitListInitList (SeqListSeqList&L)L)L.data=(L.data=(ListData ListData*)*)malloc malloc (ListSize ListSize
7、*sizeof sizeof (ListData ListData);if if(L.data(L.data=NULL)NULL)printfprintf (“(“存储分配失败存储分配失败存储分配失败存储分配失败!n”n”);exit exit(1)(1);L.length=0 L.length=0;5/25/20249北京化工大学信息学院 数据结构n n 求表的长度求表的长度 int Length(SeqList&L)return L.length;n n按位置查找:在表中提取第按位置查找:在表中提取第 i 个元素的值个元素的值 ListData GetData(SeqList&L,int
8、i)if (i=0&i L.length)return L.datai;else printf(“参数 i 不合理!n”);/在出错情况,函数返回值不能用!5/25/202410北京化工大学信息学院 数据结构int Find(SeqList&L,ListData x)int i=0;while(i L.length&L.datai!=x)i+;if(i L.length)return i;else return-1;(在顺序表中从头查找结点值等于给定值(在顺序表中从头查找结点值等于给定值(在顺序表中从头查找结点值等于给定值(在顺序表中从头查找结点值等于给定值 x x 的结点)的结点)的结点)的
9、结点)按值查找按值查找5/25/202411北京化工大学信息学院 数据结构顺序查找图示顺序查找图示25 34 57 16 48 09 0 1 2 3 4 5 data查找查找 16 i25 34 57 16 48 09 i25 34 57 16 48 09 i25 34 57 16 48 09 i查找成功查找成功5/25/202412北京化工大学信息学院 数据结构25 34 57 16 48 0 1 2 3 4data查找 50i25 34 57 16 48 i25 34 57 16 48 i25 34 57 16 48 i25 34 57 16 48 i查找失败查找失败5/25/202413
10、北京化工大学信息学院 数据结构查找成功的平均比较次数查找成功的平均比较次数 若查找概率相等,则若查找概率相等,则查找不成功查找不成功 数据比较数据比较 n 次次5/25/202414北京化工大学信息学院 数据结构顺序表的插入顺序表的插入25 34 57 16 48 09 63 0 1 2 3 4 5 6 7data50插入 x25 34 57 50 16 48 09 63 0 1 2 3 4 5 6 7data50i5/25/202415北京化工大学信息学院 数据结构int Insert(SeqList&L,ListData x,int i)/在表中第 i 个位置插入新元素 x if(i L.
11、length|L.length=ListSize)return 0;/插入不成功 else for(int j=L.length;j i;j-)L.dataj=L.dataj-1;L.datai=x;L.length+;return 1;/插入成功 顺序表的插入顺序表的插入5/25/202416北京化工大学信息学院 数据结构顺序表的删除顺序表的删除25 34 57 50 16 48 09 63 0 1 2 3 4 5 6 7data16删除 x25 34 57 50 48 09 63 0 1 2 3 4 5 6 7data5/25/202417北京化工大学信息学院 数据结构int Delete
12、(SeqList&L,ListData x)/在表中删除已有元素 x int i=Find(L,x);/在表中查找 x if(i=0)L.length-;for(int j=i;j L.length;j+)L.dataj=L.dataj+1;return 1;/成功删除 return 0;/表中没有 x 顺序表的删除顺序表的删除5/25/202418北京化工大学信息学院 数据结构顺序表的应用:集合的顺序表的应用:集合的“并并”运算运算void Union(SeqList&A,SeqList&B)int n=Length(A);int m=Length(B);for(int i=0;i m;i+
13、)int x=GetData(B,i);/在B中取一元素 int k=Find(A,x);/在A中查找它 if(k=-1)/若未找到插入它 Insert(A,x,n);n+;5/25/202419北京化工大学信息学院 数据结构 void Intersection(SeqList&A,SeqList&B)int n=Length(A);int m=Length(B);int i=0;while(i-link=first;link=first;first=first=newnodenewnode;(插入前)(插入前)firstnewnodenewnodefirst(插入后)(插入后)5/25/20
14、2426北京化工大学信息学院 数据结构 uu 第二种情况:在链表中间插入第二种情况:在链表中间插入第二种情况:在链表中间插入第二种情况:在链表中间插入 newnodenewnode-link=plink=p-link;link;p p-link=link=newnode newnode;(插入前插入前)newnodeppnewnode(插入后插入后)5/25/202427北京化工大学信息学院 数据结构uu 第三种情况:在链表末尾插入第三种情况:在链表末尾插入第三种情况:在链表末尾插入第三种情况:在链表末尾插入 newnodenewnode-link=plink=p-link;link;p p-
15、link=link=newnodenewnode;(插入前插入前)newnodep newnodep(插入后插入后)5/25/202428北京化工大学信息学院 数据结构int Insert(LinkList&first,int x,int i)/在链表第 i 个结点处插入新元素 x ListNode*p=first;int k=0;while(p!=NULL&k link;k+;/找第 i-1个结点 if(p=NULL&first!=NULL)printf(“无效的插入位置!n”);return 0;ListNode*newnode=/创建新结点 (ListNode*)malloc(sizeo
16、f(ListNode);5/25/202429北京化工大学信息学院 数据结构 newnode-data=x;if(first=NULL|i=1)/插在表前 newnode-link=first;first=newnode;else /插在表中或末尾 newnode-link=p-link;p-link=newnode;return 1;5/25/202430北京化工大学信息学院 数据结构n n删除删除uu第一种情况第一种情况第一种情况第一种情况:删除表中第一个元素删除表中第一个元素删除表中第一个元素删除表中第一个元素uu第二种情况第二种情况第二种情况第二种情况:删除表中或表尾元素删除表中或表尾
17、元素删除表中或表尾元素删除表中或表尾元素在单链表中删除含在单链表中删除含ai的结点的结点ai-1aiai+1删除前删除前ai-1aiai+1pq删除后删除后5/25/202431北京化工大学信息学院 数据结构int Delete(LinkList&first,int i)/在链表中删除第 i 个结点 ListNode*p,*q;if(i=1)/删除表中第 1 个结点 q=first;first=first-link;else p=first;int k=0;/找第 i-1个结点 while(p!=NULL&k link;k+;5/25/202432北京化工大学信息学院 数据结构 if(p=NU
18、LL|p-link=NULL)printf(“无效的删除位置!n”);return 0;else /删除表中或表尾元素 q=p-link;/重新链接 p-link=q-link;free(q);/删除q return 1;5/25/202433北京化工大学信息学院 数据结构带表头结点的单链表带表头结点的单链表n n表头结点位于表的最前端,本身不带数据,表头结点位于表的最前端,本身不带数据,表头结点位于表的最前端,本身不带数据,表头结点位于表的最前端,本身不带数据,仅标仅标仅标仅标志表头志表头志表头志表头。n n设置表头结点的目的是设置表头结点的目的是设置表头结点的目的是设置表头结点的目的是uu
19、统一空表与非空表的操作统一空表与非空表的操作统一空表与非空表的操作统一空表与非空表的操作uu简化链表操作的实现。简化链表操作的实现。简化链表操作的实现。简化链表操作的实现。非空表非空表 空表空表0ana1firstfirst05/25/202434北京化工大学信息学院 数据结构在带表头结点的单链表在带表头结点的单链表 第一个结点前插入新结点第一个结点前插入新结点 newnode-link=p-link;p-link=newnode;firstnewnodefirstnewnode插入firstnewnode0firstnewnode0插入pppp5/25/202435北京化工大学信息学院 数据
20、结构 q=p-link;p-link=q-link;free q;从带表头结点的单链表中删除第一个结点从带表头结点的单链表中删除第一个结点firstfirst(非空表)非空表)first0first(空表)空表)0pqpq5/25/202436北京化工大学信息学院 数据结构前插法建立单链表前插法建立单链表n n从一个空表开始,重复读入数据:从一个空表开始,重复读入数据:从一个空表开始,重复读入数据:从一个空表开始,重复读入数据:uu生成新结点生成新结点生成新结点生成新结点uu将读入数据存放到新结点的数据域中将读入数据存放到新结点的数据域中将读入数据存放到新结点的数据域中将读入数据存放到新结点的
21、数据域中uu将该新结点插入到链表的前端将该新结点插入到链表的前端将该新结点插入到链表的前端将该新结点插入到链表的前端n n直到读入结束符为止直到读入结束符为止直到读入结束符为止直到读入结束符为止。firstnewnodefirstnewnode005/25/202437北京化工大学信息学院 数据结构LinkList createListF(void)char ch;ListNode*s;LinkList head=/建立表头结点 (LinkList)malloc(sizeof(ListNode);head-link=NULL;while(ch=getchar()!=n)s=(listNode*
22、)malloc(sizeof(ListNode);s-data=ch;/建立新结点 s-link=head-link;/插入到表前端 head-link=s;return head;5/25/202438北京化工大学信息学院 数据结构后插法建立单链表后插法建立单链表n n每次将新结点加在链表的表尾;每次将新结点加在链表的表尾;每次将新结点加在链表的表尾;每次将新结点加在链表的表尾;n n设置一个尾指针设置一个尾指针设置一个尾指针设置一个尾指针 r r,总是指向表中最后一个结总是指向表中最后一个结总是指向表中最后一个结总是指向表中最后一个结点,新结点插在它的后面;点,新结点插在它的后面;点,新结
23、点插在它的后面;点,新结点插在它的后面;n n尾指针尾指针尾指针尾指针 r r 初始时置为指向表头结点地址。初始时置为指向表头结点地址。初始时置为指向表头结点地址。初始时置为指向表头结点地址。00newnodefirstnewnode00rrrr5/25/202439北京化工大学信息学院 数据结构LinkList createListR(void)char ch;LinkList head=/建立表头结点 (LinkList)malloc(sizeof(ListNode);ListNode*s,*r=head;/r指向表尾 while(ch=getchar()!=n)s=(listNode*)
24、malloc(sizeof(ListNode);s-data=ch;/建立新结点 r-link=s;r=s;/插入到表末端 r-link=NULL;/表收尾 return head;5/25/202440北京化工大学信息学院 数据结构firstqfirstfirstqqfirsta0a1a1a2a2a2单链表清空单链表清空5/25/202441北京化工大学信息学院 数据结构单链表清空单链表清空void void makeEmptymakeEmpty(LinkListLinkList first)first)/删去链表中除表头结点外的所有其他结点删去链表中除表头结点外的所有其他结点删去链表中除表
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- ds200902 线性
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。