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,关注后即可获取最新文章推送

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

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

  1. linux shell 中数组的定义和for循环遍历的方法

    linux 中定义一个数据的语法为: variable=(arg1 arg2 arg3 ....) 中间用空格分开.数组的下标从0开始. 1 获取下标为n的元素: variable[n] 而且不存在数 ...

  2. 功能要求:定义一个两行三列的二维数组 names 并赋值,使用二重循环输出二维数组中的元素。

    功能要求:定义一个两行三列的二维数组 names 并赋值,使用二重循环输出二维数组中的元素 names={{"tom","jack","mike&qu ...

  3. 三重for循环实现对二维数组的按列排序(JavaScript)

    由C语言联想到的:三重for循环实现对二维数组的按列排序,并且牵扯到数据结构. 自己写的,水平有限,本文属于原创,可能存在错误,忘指正~ function circle() { var a = [ [ ...

  4. 【c语言】二维数组中的查找,杨氏矩阵在一个二维数组中,每行都依照从左到右的递增的顺序排序,输入这种一个数组和一个数,推断数组中是否包括这个数

    // 二维数组中的查找,杨氏矩阵在一个二维数组中.每行都依照从左到右的递增的顺序排序. // 每列都依照从上到下递增的顺序排序.请完毕一个函数,输入这种一个数组和一个数.推断数组中是否包括这个数 #i ...

  5. 【面试题003】c数组做为参数退化的问题,二维数组中的查找

    [面试题003]c数组做为参数退化的问题,二维数组中的查找  一,c数组做为参数退化的问题 1.c/c++没有记录数组的大小,因此用指针访问数组中的元素的时候,我们要确保没有超过数组的边界, 通过下面 ...

  6. 二维数组过滤,根据多个条件获取二维数组中指定的arr

    /** * 二维数组过滤,根据多个条件获取二维数组中指定的arr * @param $data_arr * @param $lm_number * @param $source_type * @par ...

  7. Go语言入门教程系列——函数、循环与分支

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Golang专题的第四篇,这一篇文章将会介绍golang当中的函数.循环以及选择判断的具体用法. 函数 在之前的文章当中其实我们已经接 ...

  8. C语言数组篇(五)多级指针和二维数组指针的区别

    多级指针   以二级指针为例 二级指针的由来是 指针数组 的指针形式. int *p[10] 读取的顺序是 p[] --> 10个空间的数组 * p[] --> 这10个空间的数组里面存放 ...

  9. 计算机二级-C语言-对标志位的巧妙使用。对二维数组数据进行处理。对文件进行数据输入。

    //函数fun的功能是:计算形参x所指数组中平均值(规定所有数均为正数),将所指数组中大于平均值的数据移至数组的前部,小于等于的移至后部,平均值作为返回值,在主函数中输出平均值和后移的数据. //重难 ...

  10. 数组属性的习题、Arrays工具、二维数组

    一.数组的练习 1.声明一个char类型的数组, 从键盘录入6个字符: [1]遍历输出 [2]排序 [3]把char数组转化成一个逆序的数组. import java.util.Scanner; pu ...

随机推荐

  1. DataGear 制作支持表单交互和多图表联动的数据可视化看板

    对于数据可视化,有时需要根据用户输入的查询条件展示限定范围的数据图表,DataGear的看板表单功能可以快速方便地实现此类需求. 下面的看板示例,包含一个柱状图.一个饼图和一个地图,用户可以通过看板表 ...

  2. 2024年,提升Windows开发和使用体验实践 - 小工具篇

    前言 本来是一篇文章的,不知不觉写成了系列. 其实开工那几天就已经写好了长文,这几天一忙就没连着发了. 本文介绍一些 Windows 上用的小工具. 美化/折腾/小工具 虽然这是在用 Windows ...

  3. 从0开始入门智能知识库和星火大模型,打造AI客服。

    介绍FastWiki FastWiki是一个高性能.基于最新技术栈的知识库系统,旨在为大规模信息检索和智能搜索提供解决方案.它采用微软Semantic Kernel进行深度学习和自然语言处理,在后端使 ...

  4. 摆脱鼠标操作 vscode-vim-use-readme.md

    vscode-vim 学习笔记 梳理下自己定义的快捷键 Normal模式返回 ESC capsLock 双击shift ctrl+[ jj ctrl+c (这个键比较特殊 用习惯y的话,考虑这个) 一 ...

  5. 手动将jar包安装到本地仓库并使用tomcat运行

    参考,欢迎点击原文:https://www.cnblogs.com/panchanggui/p/10696458.html 公司有个老项目是spring的,要我们自己本地安装,我发现我maven一直报 ...

  6. Java诊断工具Arthas:开篇之watch实战

    Arthas是阿里开源的线上监控诊断产品,用于问题的排查和诊断. 它的出现大大提高线上排查问题的效率,这篇只讲它一个非常牛逼的功能,其它功能往后篇章会在展开详细说. 一.Arthas能为你做什么? 1 ...

  7. C++ explicit 关键字简介

    explicit 关键字修饰构造函数 防止类的初始化的时候进行隐式转换. class MyClass { string m_s; int m_a, m_b; public: MyClass(strin ...

  8. FFmpeg命令行之FFmpeg 采集设备

    在使用 FFmpeg 作为编码器时,可以使用FFmpeg采集本地的音视频采集设备的数据,然后进行编码.封装.传输等操作. 例如,我们可以采集摄像头的图像作为视频,采集麦克风的数据作为音频,然后对采集的 ...

  9. x86架构的内存溢出攻击原理演示(加强对计算机运行原理的理解,说明内存溢出的危害)

    PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 前置说明   本文作为本人csdn blog的主站的备份.(Bl ...

  10. Walrus 0.6发布:预览资源变更、丰富公有云支持,满足企业多云需求

    近日,数澈软件Seal(以下简称"Seal")宣布基于 IaC 的开源应用管理平台 Walrus 0.6 正式发布! 在之前的版本中,Walrus 引入应用模型并优化了应用部署体验 ...