数组(C语言)(详细过程!!!)

目录

数组的概念

一维数组  

sizeof计算数组元素个数 

二维数组

C99中的变⻓数组


数组的概念

数组是⼀组相同类型元素的集合。 数组分为⼀维数组和多维数组,多维数组⼀般比较多见的是二维数组。

从这个概念中我们就可以发现2个有价值的信息:(1)数组中存放的是1个或者多个数据,但是数组元素个数不能为0。  (2)数组中存放的多个数据,类型是相同的。 

一维数组

1. 在学习一维数组之前我们先了解它的语法结构:type  arr_name[常量值]存放在数组的值被称为数组的元素,数组在创建的时候可以指定数组的大小和数组的元素类型。type 指定的是数组中存放数据的类型,可以是: char 、 short 、 int 、 float 等,也可以自定义的类型; ar r_name 指的是数组名的名字,这个名字根据实际情况,起的有意义就行; [   ] 中的常量值是用来指定数组的大小的,这个数组的大小是根据实际的需求指定就行。

2. 一维数组的创建和初始化

创建:例如现在我们要计算20个人的数学成绩,int math[20],这个就可以表示20个人的数学成绩,类型是int整型,另外要跟大家说的是int [20]和int [5]的类型是不一样的,是因为元素的个数是不同的,大家要记住这一点。

初始化:数组的初始化分为两种,一种是完全初始化,一种是不完全初始化,下面这张图给大家解释:

我们要注意的是在给数组初始化的时候一般后面使用大括号{  }的,我们可以选择完全初始化和不完全初始化,这就要看我们如何使用数组,下面给大家讲解如何使用一维数组。

3. 一维数组的使用

(1)第一我们要认识数组下标,C语言规定数组是有下标的,下标是从0开始的,假设数组有n个元素,最后⼀个元素的下标是n-1,下 标就相当于数组元素的编号,如下:在C语言中数组的访问提供了⼀个操作符 [  ] ,这个操作符叫:下标引用操作符。 有了下标访问操作符,我们就可以轻松的访问到数组的元素了,比如我们访问下标为2的元素,我们就可以使arr[2] ,想要访问下标是3的元素,就可以使⽤ arr[3] ,如下代码:

int main()
{int a[6] = { 1,2,3,4,5,6 };printf("%d\n", a[2]);printf("%d\n", a[3]);return 0;
}

(2)第二就是如何打印数组的内容,只要我们产⽣数组所有元素的下标就可以了,那我们使用for循环产⽣0~9的下标,接下来使用下标访 问就行了。 如下代码:

 #include <stdio.h>int main(){int arr[10] = {1,2,3,4,5,6,7,8,9,10}; int i = 0;for(i=0; i<10; i++){printf("%d ", arr[i]);}return 0;}

(3)第三就是对数组的输入,明白了数组的访问,当然我们也根据需求,自己给数组输⼊想要的数据,如下:

#include <stdio.h>
int main()
{int arr[10]={1,2,3,4,5,6,7,8,9,10};int i=0;for(i=0;i<10;i++){scanf("%d",&arr[i];}for(i=0;i<10;i++){printf("%d",arr[i]);}return 0;
}

那么这个代码就是我们可以自己输入数组的元素,然后再打印出来。

(4)第四是一维数组在内存中的储存,有了前⾯的知识,我们其实使用数组基本没有什么障碍了,如果我们要深入了解数组,我们最好能了 解⼀下数组在内存中的存储。 依次打印数组元素的地址,如下代码:

 #include <stdio.h>int main(){int arr[10] = {1,2,3,4,5,6,7,8,9,10}; int i = 0;for(i=0; i<10; i++){printf("&arr[%d] = %p\n ", i, &arr[i]);}return 0;}

从输出的结果我们分析,数组随着下标的增⻓,地址是由⼩到⼤变化的,并且我们发现每两个相邻的 元素之间相差4(因为⼀个整型是4个字节)。所以我们得出结论:数组在内存中是连续存放的。这就 为后期我们使用指针访问数组奠定了基础。

sizeof计算数组元素个数 

在遍历数组的时候,我们经常想知道数组的元素个数,那C语言中有办法使用程序计算数组元素个数 吗? 答案是有的,可以使用sizeof。 sizeof 中C语⾔是⼀个关键字,是可以计算类型或者变量大小的,其实 sizeof也是可以计算数组的大小的。 如下代码:

 #include <stido.h>int main(){int arr[10] = {0};printf("%d\n", sizeof(arr));return 0;}

这里输出的结果是40,计算的是数组所占内存空间的总大小,单位是字节。 我们又知道数组中所有元素的类型都是相同的,那只要计算出⼀个元素所占字节的个数,数组的元素 个数就能算出来。这里我们选择第⼀个元素算大小就可以 ,也就是用所有字节除上一个一个元素的字节就可以得到元素的个数。

 #include <stido.h>int main(){int arr[10] = {0};int sz = sizeof(arr)/sizeof(arr[0]);printf("%d\n", sz);return 0;}

  这里输出的10就是有多少个元素 ,也就是我们所要求的元素个数。

二维数组

学习了一维数组,下面给大家讲解二维数组,如果我们把⼀维数组做为数组的元 素,这时候就是⼆维数组,⼆维数组作为数组元素的数组被称为三维数组,⼆维数组以上的数组统称 为多维数组。其实二维数组的用法与一维数组的用法也有很多相同之处,下面给大家一一讲解: 

1.二维数组的创建和初始化

(1) 语法:type arr_name[ 常量值 1][ 常量值 2] ;例如: int arr[3][5]; double data[2][8]; 3表示数组有3行,5表示每一行有5个元素,int表示数组的每个元素是整型类型, arr是数组名,可以根据自己的需要指定名字,data数组意思基本⼀致。

(2)初始化:二维数组的初始化也有完全初始化和不完全初始化,稍有不同的是怎么去初始化,下面给大家附上一张图一次性说清楚:

 2.二维数组的使用

(1)⼆维数组的下标 :当我们掌握了⼆维数组的创建和初始化,那我们怎么使⽤⼆维数组呢? 其实⼆维数组访问也是使⽤下标的形式的,二维数组是有行和列的,只要锁定了行和列就能唯⼀锁定 数组中的⼀个元素。 C语⾔规定,⼆维数组的行是从0开始的,列也是从0开始的,如下所示:

 #include <stdio.h>int main(){int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};printf("%d\n", arr[2][4]);return 0;}//根据上图也就知道输出的结果是7

(2)二维数组的输入和输出:访问⼆维数组的单个元素我们知道了,那如何访问整个⼆维数组呢? 其实我们只要能够按照⼀定的规律产⽣所有的⾏和列的数字就⾏;以上⼀段代码中的arr数组为例, 行的选择范围是0~2,列的取值范围是0~4,所以我们可以借助循环实现⽣成所有的下标。  

(3)二维数组在内存中的存储:像⼀维数组⼀样,我们如果想研究⼆维数组在内存中的存储⽅式,我们也是可以打印出数组所有元素 的地址的。代码如下: 

从输出的结果来看,每⼀⾏内部的每个元素都是相邻的,地址之间相差4个字节,跨⾏位置处的两个元 素(如:arr[0][4]和arr[1][0])之间也是差4个字节,所以⼆维数组中的每个元素都是连续存放的。

C99中的变长数组

在C99标准之前,C语⾔在创建数组的时候,数组大小的指定只能使⽤常量、常量表达式,或者如果我 们初始化数据的话,可以省略数组大小。 如:

这样的语法限制,让我们创建数组就不够灵活,有时候数组⼤了浪费空间,有时候数组⼜⼩了不够⽤ 的。 C99中给⼀个变长数组(variable-lengtharray,简称VLA)的新特性,允许我们可以使用变量指定数组大小。 请看下⾯的代码:  上⾯⽰例中,数组 arr 就是变长数组,因为它的长度取决于变量 n 的值,编译器没法事先确定,只 有运行时才能知道 n 是多少。 变⻓数组的根本特征,就是数组⻓度只有运⾏时才能确定,所以变⻓数组不能初始化。它的好处是程 序员不必在开发时,随意为数组指定⼀个估计的⻓度,程序可以在运⾏时为数组分配精确的⻓度。有 ⼀个⽐较迷惑的点,变⻓数组的意思是数组的大小是可以使用变量来指定的,在程序运⾏的时候,根 据变量的⼤⼩来指定数组的元素个数,而不是说数组的大小是可变的。数组的⼤⼩⼀旦确定就不能再 变化了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/26425.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端路由的介绍

前端路由 是用于实现页面间导航的一种技术&#xff0c;在不重新加载整个页面的情况下&#xff0c;通过改变地址栏的URL来更新内容。前端路由通常用于单页应用中&#xff0c;为用户提供更流畅的体验。 前端路由的工作原理 主要依赖于浏览器的History API(popstate, pushState…

什么是相对路径?什么是绝对路径?打包时路径怎么搞?

简单点说&#xff1a; 绝对路径&#xff1a;绝对路径是一个完整的路径&#xff0c;从根目录开始一直到目标文件或目录的路径。通常我们直接使用"/ "代表从根目录开始的目录路径。它提供了文件或目录在文件系统中的确切位置&#xff0c;与当前工作目录无关。绝对路径…

AMS深入浅出

目标&#xff1a; 1. 一、AMS启动流程 ActivityManagerService是 安卓10 以后&#xff0c;将AMS拆分出ActivityTaskManagerService。 1.1 启动入口 AMS是由SystemServer进程启动&#xff0c;在启动过程 startBootStripService&#xff0c;会启动AMS和ATMS服务。 SystemSe…

外卖跑腿APP开发指南:探索同城O2O系统源码技术要点

同城O2O系统作为这类服务的技术支撑平台&#xff0c;承载了外卖跑腿APP的开发与运行。本篇文章&#xff0c;小编将深入探讨同城O2O系统源码的技术要点&#xff0c;为外卖跑腿APP的开发提供指导与参考。 一、同城O2O系统概述 同城O2O系统是一种基于地理位置的线上到线下服务平台…

“论多源数据集成及应用”必过范文,突击2024软考高项论文

论文真题 在如今信息爆炸的时代&#xff0c;企业、组织和个人面临着大量的数据。这些数据来自不同的渠道和资源&#xff0c;包括传感器、社交媒体、销售记录等&#xff0c;它们各自具有不同的数据格式、分布和存储方式。因此如何收集、整理和清洗数据&#xff0c;以建立一个一…

阅读源码解析dynamic-datasource-spring-boot-starter中是如何动态切换数据源的

dynamic-datasource-spring-boot-starter是苞米豆提供的一个动态切换数据源的工具&#xff0c;可以帮助企业或者个人实现多数据源的切换&#xff0c;这里通过阅读源码的方式解析是如何动态的切换数据源的&#xff0c;采用的版本是3.5.1 源码解析 通过官方文档可以看到&#x…

vue 和 js写屏幕自适应

实现屏幕自适应的方式有很多种&#xff0c;可以通过插件本身提供的方法&#xff0c;可以通过flex布局等&#xff0c;今天我们来写写通过js实现屏幕自适应。 以下是在vue中实现的屏幕自适应 首先在data中定义一下屏幕的默认大小和缩放比例 然后在mounted中获取窗口的内置宽高&a…

揭秘软件测试秘籍:测试用例设计方法大揭秘

文章目录 引言一、等价类划分1.1 定义1.2 步骤1.3 等价类划分优点和缺点 二、边界值分析法2.1 定义2.2 步骤2.3 边界值分析法的优点和缺点 三、判定表法3.1 定义3.2 步骤3.3 判定表组成不分3.4 判定表的优点和缺点 四、正交实验法4.1 定义4.2 步骤4.3 正交实验法的优点和缺点 五…

2024.05.31 校招 实习 内推 面经

绿*泡*泡VX&#xff1a; neituijunsir 交流*裙 &#xff0c;内推/实习/校招汇总表格 1、实习 | 上汽集团零束科技2024「ZONE引擎」&#xff08;内推&#xff09; 实习 | 上汽集团零束科技2024「ZONE引擎」计划正式启动&#xff08;内推&#xff09; 2、实习 | 华为上海海思…

基于Verilog表达的FSM状态机

基于Verilog表达的FSM状态机 1 FSM1.1 Intro1.2 Why FSM?1.3 How to do 在这里聚焦基于Verilog的三段式状态机编程&#xff1b; 1 FSM 1.1 Intro 状态机是一种代码实现功能的范式&#xff1b;一切皆可状态机&#xff1b; 状态机编程四要素&#xff1a;– 1.状态State&#…

基于51单片机的简易温控水杯恒温杯仿真设计( proteus仿真+程序+设计报告+讲解视频)

基于51单片机的简易温控水杯恒温杯仿真设计( proteus仿真程序设计报告讲解视频&#xff09; 仿真图proteus7.8及以上 程序编译器&#xff1a;keil 4/keil 5 编程语言&#xff1a;C语言 设计编号&#xff1a;S0099 1. 主要功能&#xff1a; 基于51单片机的简易温控水杯恒温…

Hudi extraMetadata 研究总结

前言 研究总结 Hudi extraMetadata ,记录研究过程。主要目的是通过 extraMetadata 保存 source 表的 commitTime (checkpoint), 来实现增量读Hudi表写Hudi表时,保存增量读状态的事务性,实现类似于流任务中的 exactly-once 背景需求 有个需求:增量读Hudi表关联其他Hudi…

cuda 架构设置

import torch torch.cuda.get_device_capability(0) 添加cmake options&#xff1a; -DCMAKE_CUDA_ARCHITECTURES86 -DCMAKE_CUDA_COMPILER/usr/local/cuda-11.8/bin/nvcc cmake工程出现“CMAKE_CUDA_ARCHITECTURES must be non-empty if set.“的解决方法_failed to detec…

振动棒出口欧盟CE认证测试项目介绍

振动棒出口欧盟CE认证测试项目介绍 一、CE认证概述 CE认证是欧盟市场的一种强制性认证&#xff0c;主要用于确保产品符合欧盟内的基本安全、健康和环保要求。对于许多产品&#xff0c;特别是电子电气产品&#xff0c;CE标志是进入欧盟市场的必要条件。振动棒作为成人用品&…

【附带源码】机械臂MoveIt2极简教程(六)、第三个demo -机械臂的避障规划

系列文章目录 【附带源码】机械臂MoveIt2极简教程(一)、moveit2安装 【附带源码】机械臂MoveIt2极简教程(二)、move_group交互 【附带源码】机械臂MoveIt2极简教程(三)、URDF/SRDF介绍 【附带源码】机械臂MoveIt2极简教程(四)、第一个入门demo 【附带源码】机械臂Move…

中介子方程十四

X$XFX$XEXyXαXiX$XαXiXrXkXtXyX$XpXVX$XdXuXWXαXWXuXdX$XVXpX$XyXtXkXrXiXαX$XiXαXyXEX$XFX$XEXyXαXiX$XαXiXrXkXtXyX$XpXVX$XdXuXWXαXWXuXdX$XVXpX$XyXtXkXrXiXαX$XiXαXyXEX$XαXηXtXαX$XWXyX$XyXWX$XpXαXqXηX$XeXαXhX$XdX$XpX$XdX$XyXeXαX$XEXyXαXiX$XαXiX…

Java 获取客户端 IP 地址【工具类】

Java 获取客户端 IP 地址 import javax.servlet.http.HttpServletRequest; import java.net.InetAddress;/*** 网络工具类*/ public class NetUtils {/*** 获取客户端 IP 地址** param request 请求* return {link String}*/public static String getIpAddress(HttpServletReq…

Apache Flink 如何保证 Exactly-Once 语义

一、引言 在大数据处理中&#xff0c;数据的一致性和准确性是至关重要的。Apache Flink 是一个流处理和批处理的开源平台&#xff0c;它提供了丰富的语义保证&#xff0c;其中之一就是 Exactly-Once 语义。Exactly-Once 语义确保每个事件或记录只被处理一次&#xff0c;即使在…

源码编译构建LAMP

Apache 起源 源于A Patchy Server&#xff0c;著名的开源Web服务软件1995年时&#xff0c;发布Apache服务程序的1.0版本由Apache软件基金会&#xff08;ASF)负责维护最新的名称为“Apache HTTP Server”官方站点&#xff1a;http://httpd.apache.org/ 主要特点 开发源代码/…

Mysql union语句

开源项目SDK&#xff1a;https://github.com/mingyang66/spring-parent 个人文档&#xff1a;https://mingyang66.github.io/raccoon-docs/#/ mysql union操作符用于连接两个以上的select语句的结果组合到一个结果集&#xff0c;并去除重复的行&#xff0c;每个select语句的雷叔…