二维数组在内存中存储是线性连续的,可以计算出二维数组的偏移量,进而使用一级指针遍历二维数组
/**
使用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\n", *pArray);
printf("array[1][2] = %d\n", *(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\t",*(pArray+i*cols+j));//访问i行j列的二维数组元素
}
printf("\n");
}
}
结果:
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\n", pArray[0][0]);
printf("array[1][2] = %d\n", 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\t",pArray[i][j]);
/*
[]运算符的结合方向是由左向右,pArray[1][2]就等价于(* (pArray + 1))[2],
而由于pArray是数组指针,而且数组的长度为3,
所以* (pArray + 1):表示跨过3个元素,而也就是到array第二行
即表示array[1]这个数组,则pArray[1][2]则就完全等价于array[1][2]。
*/
}
printf("\n");
}
}
结果:
array[0][0] = 1
array[1][2] = 6
1 2 3
4 5 6