- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构授课教案第章
山东轻工业学院
教师授课教案
课程名称: 数据结构(计科) 课程代码: 0301306 学 分: 4.5 课程类别: 必修 开课单位: 信息科学与技术学院 授课班级: 授课教师: 杨春花
山东轻工业学院教务处制
授课时间 年 月 日 星期 第 节
年 月 日 星期 第 节
年 月 日 星期 第 节 授课内容概要 第五章 数组和广义表
第一节 数组的定义
数组的顺序表示和实现矩阵的压缩存储广义表广义表广义表广义表基本:了解特殊矩阵的压缩存储方法理解数组的概念和数组的存储结构;特殊矩阵和稀疏矩阵的压缩存储方法。特殊矩阵的压缩存储方法
前4章介绍的数据结构共同特点:
1)都属于线性数据结构;2)每种数据结构中的数据元素,都作为原子数据,不再进行分解;
本章讨论的两种数据结构:数组和广义表,其共同特点是:
1)从逻辑结构上看它们,可看成是线性结构的一种扩展;2)数据元素本身也是一个数据结构;
5.1 数组的定义和运算
一、数组的概念
1、n维数组:
n维数组是由∏bi个元素组成,每个元素受着n个关系的约束。在每个关系中,元素aj1,j2,…,jn(0≤ji≤bi-2)都有一个后继。故这n个关系是线性关系。
数组中的所有元素必须属于同一数据类型。每个元素都对应一组下标(j1,j2,…jn),每个下标的范围0≤ji≤bi-1,bi称为第i维的长度。∏bi为n维数组的长度。
当n=1时,n维数组退化为定长的线性表。
以二维数组为例:二维数组中的每个元素都受两个线性关系的约束即行关系和列关系,在每个关系中,每个元素aij都有且仅有一个直接前趋,都有且仅有一个直接后继。
我们可以把二维数组看成一个线性表:
A=(a 1 a 2 … aj … an),其中aj(1≤j ≤n)本身也是一个线性表,称为列向量。
还可以将数组Am×n看成另外一个线性表:
B=(b1,,b2,,… ,bm),其中bi(1≤i ≤m)本身也是一个线性表,称为行向量,即: bI= (ai1,ai2,…,aij,…,ain)。
二、数组的基本操作
1)读元素操作
2)写元素操作
操作方法根据其存储结构决定
5.2 数组的顺序表示和实现
数组一旦建立,结构中的元素个数和元素间的关系就不再发生变化。因此,一般都是采用顺序存储的方法来表示数组。
由于计算机的内存结构是一维的,因此用一维内存来表示多维数组,就有次序约定的问题。
通常有两种顺序存储方式:
⑴行优先顺序——将数组元素按行排列,第i+1个行向量紧接在第i个行向量后面。
在PASCAL、C语言中,数组就是按行优先顺序存储的。
⑵列优先顺序——将数组元素按列向量排列,第j+1个列向量紧接在第j个列向量之后。
在FORTRAN语言中,数组就是按列优先顺序存储的。以行为主序:
LOC(aij)=LOC(a00)+(i*n+j)*l
以列为主序:
LOC(aij)=LOC(a00)+(j*m+n)*l
一般地,对A[c1..d1,c2..d2]
则:以行为主序有:
LOC(aij)=LOC(ac1c2)+[(i-c1)*(d2-c2+1)+(j-c2)]*l
以列为主序:
LOC(aij)=LOC(ac1c2)+[(j-c2)*(d1-c1+1)+(i-c1)]*l
推广到n维数组Ab1b2..bn
LOC(aj1j2..jn)=LOC(a00..0)+(j1*b2*b3*…*bn+j2*b3*b4*…*bn+…+jn-1*bn+jn)*l
以列为主序:
LOC(aj1j2..jn)=LOC(a00..0)+(jn*bn-1*bn-2*…*b1+jn-1*bn-2*bn-3*…*b1+…+j2*b1+j1)*l
一般地,对A[c1..d1,c2..d2,…,cn..dn]
则:以行为主序有:
LOC(aj1j2..jn)=LOC(ac1c2..cn)+[(j1-c1)*(d2-c2+1)*(d3-c3+1)*…*(dn-cn+1)+(j2-c2)*(d3-c3+1)*(d4-c4+1)*…*(dn-cn+1)+…+(jn-1-cn-1)*(dn-cn+1)+jn-cn]*l
以列为主序:
LOC(aj1j2..jn)=LOC(ac1c2..cn)+[(jn-cn)*(dn-1-cn-1+1)*(dn-2-cn-2+1)*…*(d1-c1+1)+(jn-2-cn-2)*(dn-3-cn-3+1)*(dn-4-cn-4+1)*…*(d1-c1+1)+…+(j2
您可能关注的文档
最近下载
- 24点题目(200题)与答案种数.docx VIP
- 本特勒电动汽车平台电池包技术--本特勒BENTELER.pdf VIP
- 中国金融移动支付 远程支付应用 第4部分:文件数据格式规范.pdf VIP
- 2022年小学数学新课标解读.pdf VIP
- 河北省围场满族蒙古族自治县2025年上半年事业单位公开招聘教师岗试题含答案分析.docx VIP
- 电子工业洁净厂房设计规范完整版2024.pdf VIP
- 2024年艺术文化生活娱乐知识竞赛-趣味知识竞赛考试历年真题荟萃带答案.docx VIP
- 石油科技成果间接经济效益计算方法.ppt VIP
- 生菜全程机械化技术规范.pdf
- 行为习惯养成教育主题班会PPT课件.pptx VIP
文档评论(0)