C语言 使用指针遍历二维数组
二维数组在内存中存储是线性连续的,可以计算出二维数组的偏移量,进而使用一级指针遍历二维数组
/** 使用1级指针访问二维数组 因为数组本身在地址空间中就是连续排列的,根据行数和列数, 计算出访问单元的 地址偏移量 就可以用一级指针遍历二维数组中的所有数据。 */ #include<stdio.h> int main() { int array[2][3] ={{1,2,3},{4,5,6}}; int *pArray = NULL; pArray = array; printf("array[0][0] = %d ", *pArray); printf("array[1][2] = %d ", *(pArray + 1 * 3 + 2));//访问1行2列的二维数组 printMatirx(array,2,3);//打印2行3列的数组 return 0; } void printMatirx(int *pArray,int rows,int cols) { int i; int j; for(i=0;i<rows;i++) { for(j=0;j< cols;j++) { printf("%d ",*(pArray+i*cols+j));//访问i行j列的二维数组元素 } printf(" "); } }结果:
array[0][0] = 1 array[1][2] = 6 1 2 3 4 5 6使用指向一维数组的指针(一维数组的长度和二维数组的列数要一样)来遍历二维数组,这样的好处就是,可以向使用二维数组名那样,通过下标来访问
/** 使用指向数组的指针来遍历二维数组 */ #include<stdio.h> #define COLS 3 void printMatirx(int (*pArray)[COLS],int rows); int main() { int array[2][COLS] ={{1,2,3}, {4,5,6}}; int (*pArray)[COLS] = NULL; pArray = array; printf("array[0][0] = %d ", pArray[0][0]); printf("array[1][2] = %d ", pArray[1][2]); printMatirx(pArray,2); return 0; } void printMatirx(int (*pArray)[COLS],int rows) { int i,j; for(i=0;i<rows;i++) { for(j=0;j<COLS;j++) { printf("%d ",pArray[i][j]); /* []运算符的结合方向是由左向右,pArray[1][2]就等价于(* (pArray + 1))[2], 而由于pArray是数组指针,而且数组的长度为3, 所以* (pArray + 1):表示跨过3个元素,而也就是到array第二行 即表示array[1]这个数组,则pArray[1][2]则就完全等价于array[1][2]。 */ } printf(" "); } }结果:
array[0][0] = 1 array[1][2] = 6 1 2 3 4 5 6
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: C语言 java 获取一维数组长度
- 下一篇: C语言 查找数组中最大最小元素