第五章数组2009.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第五章数组2009

zhengzhihua 第五章 数组和广义表 数组和广义表可看成是一种特殊的线性表,其特殊在于表中的数据元素本身也是一种线性表。 第五章 数组和广义表 5.1 数组的定义 5.2 数组的顺序表示和实现 5.3 矩阵的压缩存储 5.3.1 特殊矩阵 5.3.2 稀疏矩阵 5.4 广义表的定义 5.5 广义表的存储结构 5.1 数组的定义 1. 数组的抽象数据类型定义 3、n维数组的逻辑结构的定义 4. 二维数组的结构 1 5 1 3 7 5 0 8 0 0 A= 1 8 9 2 6 3 0 2 5 1 7 0 6 1 3 4. 二维数组的结构 1 5 1 3 7 5 0 8 0 0 A= 1 8 9 2 6 3 0 2 5 1 7 0 6 1 3 5. 数组的运算 给定一个下标,存取相应的数据元素 给定一个下标,修改相应的数据元素 5.2 数组的顺序表示和实现 由于计算机的内存结构是一维的,因此用一维内存来表示多维数组,就必须按某种次序将数组元素排成一个序列,然后将这个线性序列存放在存储器中。 1.通常有两种顺序存储方式: ⑴按行优先存储 ⑵按列优先存储 2. 地址计算---按行优先存储地址计算 二维 设界偶为 1≤i ≤m , 1≤j≤n Loc(aij)=Loc(a11)+[(i-1)*n+(j-1)]*L n维 设界偶为 c1≤j1 ≤d1 … cn≤jn≤dn Loc(aj1j2…jn) = Loc(ac1…cn) +[(d2-c2+1)(d3-c3+1)…(dn-cn+1)(j1-c1) + (d3-c3+1)(d4-c4+1)…(dn-cn+1)(j2-c2) + …… + (dn-cn+1)(jn-1-cn-1) + (jn-cn)]*L 例 三维数组 设c1=c2=c3=1,d1=d2=d3=5, L=1, Loc(a111)=100 求:Loc(a234) 和 Loc(a345) Loc( a234 ) = Loc(a111)+ L*[(d2-c2+1)*(d3-c3+1)*(j1-c1) + (d3-c3+1) (j2-c2) + (j3-c3)] =100+1*[(5-1+1)*(5-1+1)*(2-1)+ (5-1+1)*(3-1)+(4-1)] =100+[5*5*1+5*2+3] =138 5.3 矩阵的压缩存储 在科学与工程计算问题中,矩阵是一种常用的数学对象,在高级语言编制程序时,简单而又自然的方法,就是将一个矩阵描述为一个二维数组。矩阵在这种存储表示之下,可以对其元素进行随机存取,各种矩阵运算也非常简单,并且存储的密度为1。但是在矩阵中非零元素呈某种规律分布或者矩阵中出现大量的零元素的情况下,看起来存储密度仍为1,但实际上占用了许多单元去存储重复的非零元素或零元素,这对高阶矩阵会造成极大的浪费,为了节省存储空间, 我们可以对这类矩阵进行压缩存储:即为多个相同的非零元素只分配一个存储空间;对零元素不分配空间。 常用稀疏矩阵的压缩存储方法: 一、顺序表示 1、三元组表 2.三元组表示的数据类型 3. 运算(三元组) 定义 TsMatrix A 创建一个三元组M 存取运算,找一个元素aij 元素改值运算 稀疏矩阵的转置 两个稀疏矩阵相加 元素改值运算 首先要查找 aij的存储地址,分情况讨论 元素改值运算 首先要查找 aij的存储地址,分情况讨论 元素改值运算 首先要查找 aij的存储地址,分情况讨论 转置运算算法 一个m×n的矩阵A,它的转置B是一个n×m的矩阵,且a[i][j]=b[j][i],0≦i≦m,0≦

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档