- 1、本文档共63页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 三对角矩阵的存储方式: 设三对角矩阵为An×n,满足: 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 A= a11 a12 0 ? … … … … … … 0 a21 a22 a23 0 … … … … … 0 0 a32 a33 a34 0 … … … … 0 … … … … … … … … … … 0 0 … … … … … an-1,n-2 an-1,n-1 an-1,n 0 0 … … … … … 0 an,n-1 ann 若将其中的非零元素按行优先顺序存放,假设每个数据元素占用一个字节的存储单元,则三对角矩阵的地址公式为: 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 Loc(aij) = Loc(a11)+2(i?1)+(j?1) 其中:i=1, j=1, 2 或:i=n, j=n-1, n 或:1in, j=i-1, i, i+1 对称矩阵的存储方式: 解决方案类似于下三角矩阵的存储。 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 稀疏矩阵: 如果一个矩阵中大多数元素为零,非零元素较少且分布无一定规律,则称之为稀疏矩阵。 顺序存储: 三元组表:线性表中的每个结点由三个字段组成,分别是该非零元素的行下标、列下标和值。 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 稀疏矩阵的C语言表示: #define smax 16 /* 最大非零元素个数 */ typedef int datatype; typedef struct { int i, j; /* 行号,列号 */ datatype v; /* 元素值 */ } node; 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 稀疏矩阵的C语言表示: typedef struct { int m, n, t; /* 行数,列数,非零元素个数 */ node data[smax]; /* 三元组表 */ } spmatrix; /* 稀疏矩阵类型 */ 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 稀疏矩阵举例:非零元素按行优先顺序存储。 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 该稀疏矩阵共有20个元素,仅有6个非零元素。其三元组表如下图所示。 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 m=4 n=5 t=6 行号域 列号域 值域 1 0 1 5 2 0 4 8 3 1 0 1 4 1 2 3 5 2 1 -2 6 3 0 6 伪地址表示法: 伪地址是指本元素在矩阵中按行优先顺序的相对位置,上述稀疏矩阵A中非零元素为: {5,8,1,3,-2,6} 非零元素的伪地址=n*i+j,n为矩阵的列数。 因此,5的伪地址为1;1的伪地址为5;…。 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 稀疏矩阵的转置运算: 一般矩阵的转置算法为: for(col=0; coln; col++) for(row=0; rowm; row++) B[col][row]=A[row][col]; 由于稀疏矩阵含有大量的零元素,因此,其转置算法修改为如下所示: 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 spmatrix ?TRANSMAT(spmatrix ?a) /* 返回稀疏矩阵A的转置 */ { int ano, bno, col; /* ano和bno分别指示a-data 和b-data中结点序号; col指示*a的列号,即*b的行号 */ pmatrix *b; /* 存放转置后的矩阵 */ b=malloc(sizeof(spmatrix)); b-m=a-n; b-n=a-m; /*行列数交换*/ b-t=a-t; 3.6.3 二维数组的结构特点—特殊矩阵的存储方式 if (b-t0) /* 有非零元素,则转置 */ { bno=0; for(col=0; cola-n; col++) /*
文档评论(0)