第5章 数组与广义表07.pptVIP

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

第5章 数组和广义表;5.1 数组的基本概念;5.1 数组的定义和特性;5.2 数组的顺序表示与实现;a00 a01 … a0,n-1 a10 a11 … a1,n-1 … … … … am-1,0 am-1,1 … am-1,n-1 ; 按上述两种方式顺序存储的数组,只要知道开始结点的地址,维数和每维的上、下界,以及每个数组元素所占用的单元数,就可以将数组元素存放地址表示为其下标的线性函数。 例如,二维数组Amn按“行优先顺序”存储在内存中,假设每个元素占用L个存储单元。 元素aij的存储地址应是数组的基地址加上排在aij前面的元素所占用的单元数。因为aij位于第i+1行、第j+1列,前面i行一共有i×n个元素,第i+1行上aij前面又有j个元素,故它前面一共有i×n+j个元素,因此,aij的地址计算函数为: LOC(i,j)=LOC(0,0)+[i×n+j]×L; 在科学与工程计算问题中,矩阵是一种常用的数学对象,在高级语言编制程序时,就是将一个矩阵描述为一个二维数组。矩阵在这种存储表示之下,可以对其元素进行随机存取,各种矩阵运算也非常简单。但是在矩阵中非零元素呈某种规律分布或者矩阵中出现大量的零元素的情况下,实际上占用了许多单元去存储重复的非零元素或零元素,这对高阶矩阵会造成极大的浪费,为了节省存储空间, 我们可以对这类矩阵进行压缩存储:即为多个相同的非零元素只分配一个存储空间;对零元素不分配空间。; 对称矩阵 若n阶矩阵A中的数据元素满足下述性质aij=aji (1≤i,j≤n)则称A为n阶对称矩阵;因aij与aji相等,二者只需分配一个存储单元。这样,可将n×n个存储单元压缩到n(n+1)/2个单元。 ; 为节约存储空间,只存对角线及对角线以上的元素,或者只存对角线及对角线以下的元素。不失一般性,假设以行主序存储下三角(包括对角线)中的元素。 以一维数组sa[n(n+1)/2]作为n阶对称矩阵A的存储结构,则sa[k]和矩阵元aij之间存在着一一对应的关系: i(i-1)/2+j-1 当i≧j j(j-1)/2+i-1 当ij; 若i≧j,则aij在下三角形中。 aij之前的i-1行(从第1行到第i-1行)一共有1+2+…+i-1=i(i-1)/2个元素,在第i行上,aij之前恰有j-1个元素,因此???: k=i (i-1)/2+j-1 若ij,则aij是在上三角矩阵中。因为aij=aji,所以只要交换上述对应关系式中的i和j即可得到: k=j (j-1)/2+i-1 注意:k从0开始,i、j从1开始。;5.3.2 三角矩阵;i(i-1)/2+j-1 当i≧j n(n+1)/2 当ij; 如果矩阵中的所有的非零元素都集中在以主对角线为中心的带状区域则称为对角矩阵,即除了主对角线和主对角线相邻两侧的若干条对角线上的元素之外,其余元素皆为零。如常见的三对角矩阵。 ;5.3.3 对角矩阵; 对角矩阵; 设矩阵Amn中有s个非零元素,若s远远小于矩阵元素的总数(即sm×n),则称A为稀疏矩阵。 稀疏矩阵的三元组表表示 在存储稀疏矩阵时,为了节省存储单元,很自然地想到使用压缩存储方法。但由于非零元素的分布一般是没有规律的,因此在存储非零元素的同时,还必须同时记下它所在的行和列的位置(i,j)。一个三元组(i,j,aij)唯一确定了矩阵A的一个非零元素。因此,稀疏矩阵可由表示非零元素的三元组及其行列数唯一确定。;例如: M由{(1,2,12), (1,3,9), (3,1,-3), (3,6,14), (4,3,24), (5,2,18), (6,1,15), (6,4,-7) } 和矩阵维数(6,7)唯一确定。; 三元组顺序表 假设以顺序存储结构来表示三元组表,则可得到稀疏矩阵的一种压缩存储方法——三元顺序表。 # define MAXSIZE 12500 //非零元个数最大值 typedef struct { int i, j; //行下标和列下标 ElemType e; } Triple; typedef struct{ Triple data[MAXSIZE+1]; //非零元三元组表 int mu,nu,

文档评论(0)

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

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

1亿VIP精品文档

相关文档