二维数组中的元素内存空间是连续的,可以通过先定义首个元素的指针变量,再用循环进行对指针变量偏移来遍历:
#include <stdio.h>
int main(){
int a[3][4] = {{11,22,33,44},{12,13,14,15},{66,77,88,99}};
int i;
int j;
int *p;
p = &a[0][0]; //将数组元素首地址作为指针变量
for(i=0;i<3;i++){
for(j=0;j<4;j++){
printf("%p\n",p++);
}
}
return 0;
}
运行结果:
000000000061FDE0
000000000061FDE4
000000000061FDE8
000000000061FDEC
000000000061FDF0
000000000061FDF4
000000000061FDF8
000000000061FDFC
000000000061FE00
000000000061FE04
000000000061FE08
000000000061FE0C
但是二维数组与指针变量的偏移单位明显不同,二维数组偏移的是整个子数组,而指针变量偏移的是单个数据类型内存。数组变量可以用指针变量指向数组名,并且数组变量与二维数组跨度一致,这时数组指针相当于数组名:
#include <stdio.h>
int main(){
int a[3][4] = {{11,22,33,44},{12,13,14,15},{66,77,88,99}};
int i;
int j;
int (*p2)[4]; //数组指针跨度与二维数组一致,调用时相当于数组名
p2 = a;
for(i=0;i<3;i++){
for(j=0;j<4;j++){
printf("%d\n",*(*(p2+i)+j));
}
}
return 0;
}
也就是说p2 = a。
案例:输出二维数组任意行列的数
#include <stdio.h>
int printData(int (*p)[4],int row,int line){ //数组变量列要相同,作用等于数组名
int data;
data = *(*(p+row)+line); //符号*输出对应值
return data; //返回数值
}
void getData(int *hang,int *lie){
printf("请输入行和列:\n");
scanf("%d%d",hang,lie);
puts("done!");
}
int main(){
int a[3][4] = {{11,22,33,44},{12,13,14,15},{66,77,88,99}};
int row;
int line;
int data;
getData(&row,&line); //输入行列地址,形参调用时能传递给实参
data =printData(a,row,line); //数组名等于地址
printf("第%d行第%d列的数为:%d\n",row,line,data);
return 0;
}