二维数组传参
二维数组不同于一位数组,一维数组传参数时只需要传指针即可,无需指定大小。二维做参数时必须指定第二维的大小,否则编译不过。
void lalala(int a[][],int m, int n) //编译报错
void lalala(int a[][10],int m, int n) //编译通过
因为对于表达式a[i][j]来说,编译器认为它的含义是*(*(a+i)+j)。
而C++中的二维数组的实质是一维数组实现的,对于数组array[m][n]来说,*(array+i)实质上是(*array + i * n),也就是说a[i][j]的地址是(a+i*n+j)如果不指定第二维的大小,编译器便无法识别*(a+i)的运算方式,就无法寻址。
如果用二维指针作参数
void lalala(int **a,int m, int n) {
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
a[i][j] = i * j;
cout << &a[i][j] - *a << " ";
}
cout << "\n";
}
}
这样是能够编译通过的,但是当调用函数时,我们需要对数组进行强制类型转换(必须转换为int **,因为int **与int*[10]类型不同)。
int m = 10;
int n = 10;
int array[10][10];
lalala((int **)array,m,n);
<