- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 如何开好早会..ppt VIP
- 《机械基础》课件 孟莹 单元1--4 静力学--- 螺纹连接与螺旋机构.pptx
- 靶向二代测序在感染性疾病诊疗中的规范化应用专家共识解读PPT课件.pptx VIP
- 可编程控制器应用技术第2版[西门子S7-1200](PLC)高职全套教学课件.pptx
- 国外矿产勘查报告规范要求.pptx VIP
- 国外矿产勘查报告规范要求.pptx VIP
- 自考 新思想学习资料 15040新思想 主观题.pdf VIP
- 郑功成“社会保障学”名词解释.pdf VIP
- 《PLC应用技术(西门子上册)第2版》中职技工全套教学课件.pptx
- 澳大利亚矿产资源和矿石储量报告规范JORC2004(中文版).doc VIP
文档评论(0)