C 语言数组教程:定义、访问、修改、循环遍历及多维数组解析

本文涉及的产品
函数计算FC,每月15万CU 3个月
应用实时监控服务-应用监控,每月50GB免费额度
云原生网关 MSE Higress,422元/月
简介: 数组用于将多个值存储在单个变量中,而不是为每个值声明单独的变量。要创建数组,请定义数据类型(例如 int)并指定数组名称,后面跟着方括号 []。要将值插入其中,请使用逗号分隔的列表,并在花括号内使用

C 数组

数组用于将多个值存储在单个变量中,而不是为每个值声明单独的变量。

要创建数组,请定义数据类型(例如 int)并指定数组名称,后面跟着方括号 []

要将值插入其中,请使用逗号分隔的列表,并在花括号内使用:

int myNumbers[] = {
   25, 50, 75, 100};

现在我们已经创建了一个变量,其中包含一个包含四个整数的数组。

访问数组元素

要访问数组元素,请参阅其索引号。

数组索引从 0 开始:[0] 是第一个元素。 [1] 是第二个元素,等等。

以下语句访问 myNumbers 中第一个元素 [0] 的值:

printf("%d", myNumbers[0]);

// 输出 25

更改数组元素

要更改特定元素的值,请参阅索引号:

myNumbers[0] = 33;

循环遍历数组

您可以使用 for 循环遍历数组元素。

以下示例输出 myNumbers 数组中的所有元素:

int myNumbers[] = {
   25, 50, 75, 100};
int i;

for (i = 0; i < 4; i++) {
   
  printf("%d\n", myNumbers[i]);
}

设置数组大小

另一种常见的方法是创建数组,指定数组的大小,然后添加元素:

// 声明一个包含四个整数的数组:
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 字节。

当您使用需要良好内存管理的大型程序时,了解数组的内存大小非常有用。

但是,当您只想找出数组有多少个元素时,可以使用以下公式(将数组的大小除以一个数组元素的大小):

int myNumbers[] = {
   10, 25, 50, 75, 100};
int length = sizeof(myNumbers) / sizeof(myNumbers[0]);

printf("%d", length); // 打印 5

改进循环

在上面的数组循环部分,我们在循环条件 (i < 4) 中写了数组的大小。这并不理想,因为它只适用于特定大小的数组。

但是,通过使用上面示例中的 sizeof 公式,我们现在可以编写适用于任何大小数组的循环,这更可持续。

而不是写:

int myNumbers[] = {
   25, 50, 75, 100};
int i;

for (i = 0; i < 4; i++) {
   
  printf("%d\n", myNumbers[i]);
}

最好写:

int myNumbers[] = {
   25, 50, 75, 100};
int length = sizeof(myNumbers) / sizeof(myNumbers[0]);
int i;

for (i = 0; i < length; i++) {
   
  printf("%d\n", myNumbers[i]);
}

C 多维数组

数组,也称为单维数组。这些非常棒,是您在 C 语言编程中会经常使用的东西。然而,如果您想要将数据存储为表格形式,例如带有行和列的表格,则需要熟悉多维数组。

多维数组本质上是数组的数组。

数组可以具有任何数量的维度。我将介绍最常见的一种;二维数组 (2D)。

二维数组

二维数组也称为矩阵(带行列的表格)。

要创建整数的二维数组,请看以下示例:

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) 中元素的值:

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("%d\n", matrix[i][j]);
  }
}

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎 点赞、收藏、关注

相关文章
|
4天前
|
监控 Linux PHP
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
52 20
|
2月前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
194 14
|
2月前
|
C语言
【C语言】全局搜索变量却找不到定义?原来是因为宏!
使用条件编译和 `extern` 来管理全局变量的定义和声明是一种有效的技术,但应谨慎使用。在可能的情况下,应该优先考虑使用局部变量、函数参数和返回值、静态变量或者更高级的封装技术(如结构体和类)来减少全局变量的使用。
52 5
|
3月前
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
88 6
|
2月前
|
编译器 C语言
【C语言】宏定义在 a.c 中定义,如何在 b.c 中使用?
通过将宏定义放在头文件 `macros.h` 中,并在多个源文件中包含该头文件,我们能够在多个文件中共享宏定义。这种方法不仅提高了代码的重用性和一致性,还简化了维护和管理工作。本文通过具体示例展示了如何定义和使用宏定义,帮助读者更好地理解和应用宏定义的机制。
97 2
|
3月前
|
存储 算法 C语言
C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项
本文深入探讨了C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项,并通过案例分析展示了实际应用,旨在帮助读者提高编程效率和代码质量。
182 4
|
3月前
|
存储 缓存 算法
C语言在实现高效算法方面的特点与优势,包括高效性、灵活性、可移植性和底层访问能力
本文探讨了C语言在实现高效算法方面的特点与优势,包括高效性、灵活性、可移植性和底层访问能力。文章还分析了数据结构的选择与优化、算法设计的优化策略、内存管理和代码优化技巧,并通过实际案例展示了C语言在排序和图遍历算法中的高效实现。
73 2
|
4月前
|
人工智能 前端开发 JavaScript
拿下奇怪的前端报错(一):报错信息是一个看不懂的数字数组Buffer(475) [Uint8Array],让AI大模型帮忙解析
本文介绍了前端开发中遇到的奇怪报错问题,特别是当错误信息不明确时的处理方法。作者分享了自己通过还原代码、试错等方式解决问题的经验,并以一个Vue3+TypeScript项目的构建失败为例,详细解析了如何从错误信息中定位问题,最终通过解读错误信息中的ASCII码找到了具体的错误文件。文章强调了基础知识的重要性,并鼓励读者遇到类似问题时不要慌张,耐心分析。
|
4月前
|
存储 编译器 C语言
C语言函数的定义与函数的声明的区别
C语言中,函数的定义包含函数的实现,即具体执行的代码块;而函数的声明仅描述函数的名称、返回类型和参数列表,用于告知编译器函数的存在,但不包含实现细节。声明通常放在头文件中,定义则在源文件中。
|
4月前
|
Java 测试技术 数据安全/隐私保护
📖Java零基础-while循环语句的深度解析
【10月更文挑战第6天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
84 1

推荐镜像

更多