C语言数组介绍和用法

简介: C语言数组介绍和用法

前言

本篇文章将带大家学习C语言中的数组,数组在C语言中是一个比较重要的点,大家需要好好理解并多加使用练习。


一、数组的定义

在 C 语言中,数组是一组同类型的元素的集合。数组中的每个元素都可以通过它的下标访问,并且下标是从0开始的整数值。举个例子,下面是一个包含5个整数的数组:

int numbers[5] = {1, 2, 3, 4, 5};

我们也可以定义float和double类型的数组:

float numbers[5] = { 1.0, 2.0, 3.0, 4.0, 5.0 };
double numbers[5] = { 1.0, 2.0, 3.0, 4.0, 5.0 };

二、数组的大小

在 C 语言中,可以使用 sizeof() 运算符来获取一个数组的大小,即数组在内存中占用的字节数。例如,假设有一个整数数组 arr,可以使用以下代码获取该数组的大小:

int arr[5] = {1, 2, 3, 4, 5};
int size = sizeof(arr) / sizeof(int);

在上述代码中,sizeof(arr) 返回的是整个数组在内存中的字节数,sizeof(int) 返回一个整数类型占用的字节数。由于 arr 中包含5个整数,因此可以通过除以一个整数元素的字节数来计算数组的大小,结果为5。

数组总大小为数组元素类型大小 * 数组元素总个数


三、数组的访问方法

在 C 语言中,数组的访问通常通过下标来实现,即使用数组名和方括号内的索引来访问数组中的元素。例如,假设有以下整型数组:

int arr[5] = {1, 2, 3, 4, 5};

访问数组中的元素通常使用下标,如下所示:

int first = arr[0];    // 获取数组中的第一个元素
int third = arr[2];    // 获取数组中的第三个元素
arr[4] = 6;            // 修改数组中的第五个元素

需要注意的是,数组的下标从0开始,因此第一个元素的下标是0,最后一个元素的下标是数组大小-1。


四、使用for循环遍历数组

在 C 语言中,可以使用 for 循环遍历数组中的元素。通常情况下,可以使用数组大小来控制循环的次数。以下是遍历整型数组的示例代码:

int arr[5] = {1, 2, 3, 4, 5};
int size = sizeof(arr) / sizeof(int);   // 获取数组大小
for (int i = 0; i < size; i++) {    // 遍历数组
    printf("%d ", arr[i]);
}

在上面的代码中,首先计算出数组的大小,然后使用 for 循环遍历数组中的每个元素,输出其值。循环变量 i 作为数组的索引,从0开始到 size-1 结束。

需要注意的是,数组下标必须在合法的范围内,否则可能导致未定义的行为,例如访问越界内存。在遍历数组时,要保证数组下标不超过数组大小的范围,否则会导致程序错误。


五、数组地址的访问方法

每一个数组在内存中都会有一块属于自己的内存空间,那么我们如何来知道这块内存空间的地址呢?

在 C 语言中,可以使用数组名来获取数组的首地址,即数组中第一个元素的内存地址。对于一维数组,数组名即为数组的首地址。

例如,假设有以下整型数组:

int arr[5] = {1, 2, 3, 4, 5};

那么我们访问数组地址的方法有两种:

一种是通过数组名来访问

一种是通过对数组第一个元素取地址来访问

printf("%d\n", arr);
printf("%d\n", &arr[0]);

其实这两种访问的方法是有区别的。

使用数组名访问数组地址,可以得到整个数组在内存中的起始地址,即数组第一个元素的地址。

而使用数组第一个元素访问数组地址是指通过指向数组第一个元素的指针来访问数组元素的地址。

因为数组的第一个元素的地址就是数组在内存中的起始地址。所以使用这两种方法访问得到的结果都是相同的。

六、二维数组

在 C 语言中,二维数组是指由多行和多列构成的数组。二维数组可以看作是一种特殊的数组,它可以通过行和列的下标来访问数组中的元素。二维数组的定义可以使用以下语法:

int arr[row][col];

其中 row 和 col 分别指定了二维数组的行数和列数。例如,下面是一个声明了 3 行 4 列的二维整型数组的示例代码:

int arr[3][4];

可以使用类似于一维数组的方式对二维数组进行初始化。例如,以下代码将二维数组初始化为一个单位矩阵:

int identity[3][3] = {{1, 0, 0}, {0, 1, 0}, {0, 0, 1}};

访问二维数组的元素可以使用类似于访问一维数组的方式。例如,以下代码将访问二维数组中第二行第三列的元素:

arr[1][2] = 10;

需要注意的是,二维数组的行和列都是从 0 开始编号的。因此,二维数组的行数可以使用 sizeof(arr) / sizeof(arr[0]) 来计算,列数可以使用 sizeof(arr[0]) / sizeof(arr[0][0]) 来计算。


七、二维数组的遍历

int arr[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 ", arr[i][j]);
    }
    printf("\n");
}

这个示例代码中,二维数组 arr 被初始化为一个 3 行 4 列的矩阵,使用嵌套的两个 for 循环遍历了数组中的所有元素。对于每个元素,使用 arr[i][j] 的方式来获取它的值,并使用 printf 函数输出结果。

需要注意的是,在使用 for 循环遍历二维数组时,外层循环变量控制行,内层循环变量控制列。在每次循环中,使用 arr[i][j] 表示第 i 行第 j 列的元素。循环变量的初始值和终止条件可以根据数组的大小进行相应的调整。

结果:

总结

本篇文章讲解了数组的基本概念及数组的访问方法,这些知识点大家需要好好理解并加以练习。


相关文章
|
2天前
|
存储 编译器 C语言
C语言之数组
C语言之数组
24 0
|
2天前
|
C语言
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
|
2天前
|
C语言
在C语言中数组作为函数参数的应用与示例
在C语言中数组作为函数参数的应用与示例
17 0
|
1天前
|
存储 C语言
C语言——数组(下)
C语言——数组(下)
5 0
C语言——数组(下)
|
1天前
|
C语言
C语言——数组(上)
C语言——数组(上)
7 0
|
2天前
|
C语言
每天一道C语言编程(数组操作)
每天一道C语言编程(数组操作)
6 0
|
2天前
|
C语言
每天一道C语言编程(第一弹~):数组
每天一道C语言编程(第一弹~):数组
9 0
|
2天前
|
机器学习/深度学习 C语言
C语言三维数组的创建
该代码片段展示了如何在C语言中创建一个动态的3D数组。由于`n`在编译时未知,不能直接声明为`int f[n][n][n]`。正确的方法是使用`malloc`进行动态内存分配。首先分配`n`个`int **`,然后对每一层分配`n`个`int *`,最后每个元素分配`n`个`int`。之后可以使用这个3D数组,并在完成后正确释放内存。
11 2
|
2天前
|
C语言
数组深入剖析(C语言基础入门)
数组深入剖析(C语言基础入门)
|
2天前
|
Unix Linux 编译器
C语言中EOF的用法
C语言中EOF的用法
7 0