在C语言中,二维数组是一种常用的数据结构,用于存储和处理具有行和列结构的数据。以下是关于C语言二维数组的详细介绍:
1. 二维数组的定义
二维数组本质上是数组的数组。其定义语法如下:
c
数据类型 数组名[行数][列数];
例如,定义一个3行4列的整数二维数组:
c
int matrix[3][4];
2. 二维数组的初始化
- 全部初始化:
c
int matrix[3][4] = {
{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12}
};
- 部分初始化:只初始化部分元素,其余元素自动初始化为0。
c
int matrix[3][4] = {
{1, 2},
{5}
};
上述代码中, matrix[0][0] = 1 , matrix[0][1] = 2 , matrix[1][0] = 5 ,其余元素均为0。
3. 访问二维数组元素
可以通过双下标来访问二维数组中的元素,语法为:
c
数组名[行下标][列下标]
例如,访问 matrix 数组中第2行第3列的元素(注意下标从0开始):
c
int value = matrix[1][2];
4. 遍历二维数组
通常使用嵌套的 for 循环来遍历二维数组。
c
#include <stdio.h>
int main() {
int matrix[3][4] = {
{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12}
};
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 4; j++) {
printf("%d ", matrix[i][j]);
}
printf("\n");
}
return 0;
}
上述代码中,外层 for 循环控制行,内层 for 循环控制列,从而遍历整个二维数组并输出每个元素。
5. 二维数组作为函数参数
当二维数组作为函数参数传递时,需要在函数定义中指定数组的列数。例如:
c
#include <stdio.h>
// 函数声明
void printMatrix(int arr[][4], int rows);
int main() {
int matrix[3][4] = {
{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12}
};
printMatrix(matrix, 3);
return 0;
}
// 函数定义
void printMatrix(int arr[][4], int rows) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < 4; j++) {
printf("%d ", arr[i][j]);
}
printf("\n");
}
}
在上述代码中, printMatrix 函数接受一个二维数组和数组的行数作为参数,在函数定义中指定了数组的列数为4。
通过以上内容,你应该对C语言二维数组有了基本的了解。二维数组在许多实际应用中都非常有用,如矩阵运算、图像处理等。
标签:初始化,matrix,int,元素,C语言,二维,数组 From: https://blog.csdn.net/2301_81152393/article/details/144806133