在C语言中,可以通过以下两种方法将二维数组作为参数传递给函数:
-
使用指针传递数组:
- 将二维数组的首地址作为参数传递给函数。
- 在函数中,通过指针操作来访问数组元素。
示例代码如下:
void func(int (*arr)[M], int row, int col) { // 使用指针操作来访问数组元素 for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { printf("%d ", arr[i][j]); } printf("\n"); } } int main() { int arr[N][M] = { {1, 2, 3}, {4, 5, 6}, {7, 8, 9} }; int row = N; int col = M; // 将数组的首地址作为参数传递给函数 func(arr, row, col); return 0; }
-
使用一维数组传递数组:
- 将二维数组转换为一维数组。
- 将一维数组的首地址作为参数传递给函数。
- 在函数中,通过计算索引来访问数组元素。
示例代码如下:
void func(int *arr, int row, int col) { // 使用索引计算来访问数组元素 for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { printf("%d ", arr[i * col + j]); } printf("\n"); } } int main() { int arr[N][M] = { {1, 2, 3}, {4, 5, 6}, {7, 8, 9} }; int row = N; int col = M; // 将二维数组转换为一维数组,并将数组的首地址作为参数传递给函数 func((int *)arr, row, col); return 0; }
这两种方法都可以实现将二维数组作为参数传递给函数,选择哪种方法取决于具体的需求和编程习惯。