文档详情

第5章 数组和广义(1).ppt

发布:2017-07-30约2.94千字共29页下载文档
文本预览下载声明
第五章 数组与广义表(1);$5.1 数组的定义;#define N1 2 #define N2 3 #define N3 4 #define N4 5 typedef int DataType; /* dim(a)是用于计算a的维数,不过只能计算数组的维数,不能计算指针的维数 */ #define dim(a) (sizeof(a)/sizeof(a[0])) ? /* 定义一个一维数组,数组的元素维整型值 */ typedef DataType ARR1[N4]; ? /* 再定义一个一维数组,数组的元素维ARR1型,不过ARR1又是一个数组,所以 * ARR2 实际上是一个矩阵 */ typedef ARR1 ARR2[N3]; /* 此处完全等价为typedef int ARR2[N3][N4];*/ ? /* 按照ARR2的解释,ARR3也是一个一维数组,不过数组元素的类型是ARR2的类型 * 所有ARR3是一个三维数组 */ typedef ARR2 ARR3[N2]; /* 此处完全等价为typedef int ARR3[N2][N3][N4];*/ ? /* 分别用定义好的ARR1,ARR2,ARR3定义三个变量a, b, c */ ARR1 a; /* 此处完全等价于:int a[N4]; */ ARR2 b; /* 此处完全等价于:int b[N3][N4]; */ ARR3 c; /* 此处完全等价于:int c[N2][N3][N4]; */;void exam_1(){ for (int i=0; idim(a); i++) a[i] = i+1; ? for (int i=0; idim(b); i++) for (int j=0; jdim(b[0]); j++) b[i][j] = (i+1)*10 + (j+1); ? for (int i=0; idim(c); i++) for (int j=0; jdim(c[0]); j++) for (int k=0; kdim(c[0][0]); k++) c[i][j][k] = (i+1)*100 + (j+1)*10 + (k+1); ? printf(\nThe a is :\n); for (int i=0; idim(a); i++) printf(%4d , a[i]); printf(\n); ? printf(\nThe b is :\n); for (int i=0; idim(b); i++) { for (int j=0; jdim(b[0]); j++) printf(%4d , b[i][j]); printf(\n); } ? printf(\nthe c is:\n); for (int i=0; idim(c); i++) { for (int j=0; jdim(c[0]); j++) { for (int k=0; kdim(c[0][0]); k++) printf(%4d , c[i][j][k]); printf(\n); } printf(\n); } };;数组在内存中的排列;执行结果;$5.2 数组的顺序表示和实现;;;鞍点程序;$5.3 矩阵的压缩存储;对角阵;下三角;上三角;对角阵;$5.3 矩阵的压缩存储;$5.3 矩阵压缩存储——稀疏矩阵;稀疏矩阵;三元组顺序表——求转置(I);三元组的转置;三元组顺序表——求转置(II);;;SPMatrix * TransM1 (SPMatrix *A) { SPMatrix *B; int p,q,col; B=malloc(sizeof(SPMatrix)); /*申请存储空间*/ B-mu=A-nu; B-nu=A-mu; B-tu=A-tu;  /*稀疏矩阵的行、列、元素个数*/ if (B-tu0) { /*有非零元素则转换*/ q=0;  for (col=0; col(A-nu); col++) /*按A的列序转换*/ for (p=0; p(A-tu); p++) /*扫描整个三元组表*/ if (A-data[p].j==col ) { B-data[q].i= A-data[p].j ; B-data[q].j= A-data[p].i ;
显示全部
相似文档