C 数组
数组用于将多个值存储在单个变量中,而不是为每个值声明单独的变量。
要创建数组,请定义数据类型(例如 int
)并指定数组名称,后面跟着方括号 []
。
要将值插入其中,请使用逗号分隔的列表,并在花括号内使用:
代码语言:c复制int myNumbers[] = {25, 50, 75, 100};
现在我们已经创建了一个变量,其中包含一个包含四个整数的数组。
访问数组元素
要访问数组元素,请参阅其索引号。
数组索引从 0 开始:[0]
是第一个元素。 [1]
是第二个元素,等等。
以下语句访问 myNumbers
中第一个元素 [0]
的值:
printf("%d", myNumbers[0]);
// 输出 25
更改数组元素
要更改特定元素的值,请参阅索引号:
代码语言:c复制myNumbers[0] = 33;
循环遍历数组
您可以使用 for
循环遍历数组元素。
以下示例输出 myNumbers
数组中的所有元素:
int myNumbers[] = {25, 50, 75, 100};
int i;
for (i = 0; i < 4; i ) {
printf("%dn", myNumbers[i]);
}
设置数组大小
另一种常见的方法是创建数组,指定数组的大小,然后添加元素:
代码语言:c复制// 声明一个包含四个整数的数组:
int myNumbers[4];
// 添加元素
myNumbers[0] = 25;
myNumbers[1] = 50;
myNumbers[2] = 75;
myNumbers[3] = 100;
使用这种方法,您应该事先知道数组元素的数量,以便程序存储足够的内存。
创建数组后,您无法更改数组的大小。
获取数组大小或长度
要获取数组的大小,可以使用 sizeof
运算符:
int myNumbers[] = {10, 25, 50, 75, 100};
printf("%lu", sizeof(myNumbers)); // 打印 20
为什么结果显示 20 而不是 5,当数组包含 5 个元素时?
- 这是因为
sizeof
运算符返回类型的大小(以字节为单位)。
一个 int
类型通常是 4 个字节,因此从上面的示例中,4 x 5(4 字节 x 5 个元素)= 20 字节。
当您使用需要良好内存管理的大型程序时,了解数组的内存大小非常有用。
但是,当您只想找出数组有多少个元素时,可以使用以下公式(将数组的大小除以一个数组元素的大小):
代码语言:c复制int myNumbers[] = {10, 25, 50, 75, 100};
int length = sizeof(myNumbers) / sizeof(myNumbers[0]);
printf("%d", length); // 打印 5
改进循环
在上面的数组循环部分,我们在循环条件 (i < 4
) 中写了数组的大小。这并不理想,因为它只适用于特定大小的数组。
但是,通过使用上面示例中的 sizeof
公式,我们现在可以编写适用于任何大小数组的循环,这更可持续。
而不是写:
代码语言:c复制int myNumbers[] = {25, 50, 75, 100};
int i;
for (i = 0; i < 4; i ) {
printf("%dn", myNumbers[i]);
}
最好写:
代码语言:c复制int myNumbers[] = {25, 50, 75, 100};
int length = sizeof(myNumbers) / sizeof(myNumbers[0]);
int i;
for (i = 0; i < length; i ) {
printf("%dn", myNumbers[i]);
}
C 多维数组
数组,也称为单维数组。这些非常棒,是您在 C 语言编程中会经常使用的东西。然而,如果您想要将数据存储为表格形式,例如带有行和列的表格,则需要熟悉多维数组。
多维数组本质上是数组的数组。
数组可以具有任何数量的维度。我将介绍最常见的一种;二维数组 (2D)。
二维数组
二维数组也称为矩阵(带行列的表格)。
要创建整数的二维数组,请看以下示例:
代码语言:c复制int matrix[2][3] = { {1, 4, 2}, {3, 6, 8} };
第一个维度表示行数 2,而第二个维度表示列数 3。值按行顺序放置,可以这样可视化:
1 | 4 | 2 |
---|---|---|
3 | 6 | 8 |
访问二维数组的元素
要访问二维数组的元素,您必须指定行和列的索引号。
以下语句访问 matrix
数组第一行 (0) 和第三列 (2) 中元素的值。
int matrix[2][3] = { {1, 4, 2}, {3, 6, 8} };
printf("%d", matrix[0][2]); // 输出 2
请记住:
- 数组索引从 0 开始: 0 是第一个元素。 1 是第二个元素,等等。
更改二维数组中的元素
要更改元素的值,请参考每个维度的元素索引号:
以下示例将更改第一行 (0) 和第一列 (0) 中元素的值:
代码语言:c复制int matrix[2][3] = { {1, 4, 2}, {3, 6, 8} };
matrix[0][0] = 9;
printf("%d", matrix[0][0]); // 现在输出 9 而不是 1
循环遍历二维数组
要循环遍历多维数组,您需要为数组的每个维度设置一个循环。
以下示例输出 matrix
数组中的所有元素:
int matrix[2][3] = { {1, 4, 2}, {3, 6, 8} };
int i, j;
for (i = 0; i < 2; i ) {
for (j = 0; j < 3; j ) {
printf("%dn", matrix[i][j]);
}
}
最后
为了方便其他设备和平台的小伙伴观看往期文章:
看完如果觉得有帮助,欢迎 点赞、收藏、关注