一般来说,将二维数组传给函数时,不能省略第二维的长度,也就是说,必须像这样
void fun(int arr[][6], int n)
这样的话第二维就被固定死的。但有时,我们确实需要处理不同的二维数组,这里有一个巧妙的方法:
考虑到二维数组实际上是连续存储的,比方有数组a[3][4],那么a[0][3]后面紧跟着的元素是a[1][0],
基于这一点,就可以通过“手工”寻址,达到向函数传递不定长二维数组的目的。
#include
void fun(int *arr, int row, int col)
{
int i, j;
for (i = 0; i < row; ++i)
{
for (j = 0; j < col; ++j)
printf("%4d", arr[i * col + j]);
printf("\n");
}
}
int main()
{
int a[3][4] = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}};
fun((int *)a, 3, 4);
return 0;
}
运行结果:
1 2 3 4
5 6 7 8
9 10 11 12