最基本的遍历二维数组的方式如下:
//参数是数组的形式
void print1(int arr[3][5], int x, int y) {
int i = 0;
for (i = 0; i < x; i++) {
int j = 0;
for (j = 0; j < y; j++) {
printf("%d ", arr[i][j]);
}
printf("\n");
}
}
int main() {
int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7,} };
print1(arr, 3, 5);
return 0;
}
利用数组指针遍历代码如下:
//参数是数组指针的形式
void print2(int(*pa)[5], int x, int y) {
int i = 0;
for (i = 0; i < x; i++) {
int j = 0;
for (j = 0; j < y; j++) {
printf("%d ", *((*pa + i) + j));
}
printf("\n");
}
}
int main() {
int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7,} };
print2(arr, 3, 5);
return 0;
}
arr[3][5]可以简单的看作如下的存放形式:
1 |
2 |
3 |
4 |
5 |
2 |
3 |
4 |
5 |
6 |
3 |
4 |
5 |
6 |
7 |
而arr是数组首元素地址,而二维数组的首元素地址其实是第一行的一维数组的地址。
即: int (*pa)[5]=arr;
注:二维数组的首地址是第一行地址。
版权声明:本文为m0_63006478原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。