作者:未知 来源:从互联网收集整理并转载 #include <stdio.h> #include <iostream.h>
/* 避免Visual C的for与标准for的不同 */ #define for if (0); else for /* dim(a)是用于计算a的维数,不过只能计算数组的维数,不能计算指针的维数 */ #define dim(a) (sizeof(a)/sizeof(a[0])) /* N1到N4是几个常量,以枚举的形式定义 */ enum {N1 = 2, N2 = 3, N3 = 4, N4 = 5}; /* 这个C程序员都知道,就是将DataType定义为int型,便于扩充 */ typedef int DataType; /* 定义一个一维数组,数组的元素维整型值 */ 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]; */ /* 下面函数给大家个示例看a,b,c如何使用 */ void exam_1() { for (int i=0; i<dim(a); i++) a[i] = i+1; for (int i=0; i<dim(b); i++) for (int j=0; j<dim(b[0]); j++) b[i][j] = (i+1)*10 + (j+1); for (int i=0; i<dim(c); i++) for (int j=0; j<dim(c[0]); j++) for (int k=0; k<dim(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; i<dim(a); i++) printf("%4d ", a[i]); printf("/n"); printf("/nThe b is :/n"); for (int i=0; i<dim(b); i++) { for (int j=0; j<dim(b[0]); j++) printf("%4d ", b[i][j]); printf("/n"); } printf("/nthe c is:/n"); for (int i=0; i<dim(c); i++) { for (int j=0; j<dim(c[0]); j++) { for (int k=0; k<dim(c[0][0]); k++) printf("%4d ", c[i][j][k]); printf("/n"); } printf("/n"); } } /* 下面函数给大家演示数组在内存中的排列 */ void exam_2() { int *pn = NULL; pn = (int *)a; /* 等价于 pn = &a[0]; */ printf("/nThe a is :/n"); for (int i=0; i<sizeof(a)/sizeof(DataType); i++) printf("%4d ", pn[i]); printf("/n"); pn = (int *)b; /* 等价于 pn = &b[0][0]; */ printf("/nThe b is :/n"); for (int i=0; i<sizeof(b)/sizeof(DataType); i++) printf("%4d ", pn[i]); printf("/n"); pn = (int *)c; /* 等价于 pn = &c[0][0][0]; */ printf("/nThe c is :/n"); for (int i=0; i<sizeof(c)/sizeof(DataType); i++) printf("%4d ", pn[i]); printf("/n"); } int main(int argc, char* argv[]) { exam_1(); exam_2(); return 0; }