玩转C语言——数组初探

一、前言

        通过前面的学习,我们已了解C语言的结构变量、分支结构和循环结构。今天,我们一起来认识C语言的另一知识点——数组。先赞后看,养成习惯。

二、数组概念

        学习数组,我们要明白数组是什么。在我看来:数组是⼀组相同类型元素的集合。

        从这句话中,我们可以提取到如下的信息:

  •         数组可以存放相同的数据且类型相同。
  •         数组的1元素个数不为零。

        数组分为⼀维数组和多维数组,多维数组⼀般⽐较多⻅的是⼆维数组。

三、一维数组

        3.1 一维数组的创建

  •         存放在数组的值被称为数组的元素,数组在创建的时候可以指定数组的⼤⼩和数组的元素类型。
  •         类型说明符就是我们常用的存储类型(如:int 、short、char......)当然也可以自定义类型。
  •         数组名就是自取的名字,要取得方便阅读。
  •         []是用来确定数组大小的,可根据需要而定。

                基本创建语法如下:

​int arr1[0];//0表示元素个数short arr2[0];char arr3[0];float arr4[0];double arr5[0+1];//表达式形式也可以​

         3.2 一维数组的初始化

        在创建数组的时候,我们需要对数组进行初始化,那我们该如何进行初始化呢?且听我细细道来:

        在进行初始化时,我们一般使用大括号的形式,即把数据放入大括号中。

        初始化有分为:完全初始化和不完全初始化。

        那什么是完全初始化什么又是不完全初始化呢?可这样理解:假如你家有五口人,每个人都能分到一包饼干,这就是完全初始化;反之,则是不完全初始化。在我们写代码过程中,大多数都是用不完全初始化。

        代码如下:

        

​​int arr1[0] = { 0 };//完全初始化int arr2[2] = { 0 };//不完全初始化int arr3[3] = { 0,0 ];//不完全初始化int arr4[5];//错误初始化,在VS中会报错​​

        3.3一维数组的类型 

        数组的类型就是去除数组名就是其类型,以上述代码为例:

​
​​int arr1[0] = { 0 };//数组类型为int [0]int arr2[2] = { 0 };//数组类型为int [2]char arr3[3] = { 0,0 ];//数组类型为 char [3]​​​

        3.4 一维数组的使用 

        在学习完基本的语法后,我们就要学习对其使用了,一维数组可以存放数据,存放数据的⽬的是对数据的操作,那我们该如何使用呢?

        3.4.1 数组下标

                C语⾔规定数组是有下标的,下标是从0开始的,假设数组有n个元素,最后⼀个元素的下标是n-1,下 标就相当于数组元素的编号,如下:

                

         在C语⾔中数组的访问提供了⼀个操作符 [] ,这个操作符叫:下标引⽤操作符。 有了下标访问操作符,我们就可以轻松的访问到数组的元素了.

        3.4.2 数组的打印

                大家是不是现在很好奇一维数组是怎么打印的。在这里提供两种方法:

        法一:

#include <stdio.h>
int main()
{char arr[] = "123456";printf("%s", arr);return 0;
}

        %s可以打印字符串,因此可以采用此方法。

        法二:

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

        此方法用之前学习过的for循环,运用循环的方式,逐个打印。

        3.4.3 数组的输入 

        明白了打印,自然就明白了输入,这里仍提供两种方法。

        法一:

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

        整体思路和上述法二一样,运用for循环进行输入及打印。

        法二:

        可借助gets()进行输入。代码如下:

        

#include <stdio.h>
int main()
{char arr[2] = { 0 };int i = 0;gets(arr);printf("%s", arr);return 0;
}
        3.4.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个字节)。所以我们得出结论:数组在内存中是连续存放的。

四、二维数组 

        前⾯学习的数组被称为⼀维数组,数组的元素都是内置类型的,如果我们把⼀维数组做为数组的元 素,这时候就是⼆维数组,⼆维数组作为数组元素的数组被称为三维数组,⼆维数组以上的数组统称 为多维数组。

         4.1二维数组的创建及初始化

        我们已学习了一维数组的创建及初始化,那⼆维数组如何初始化呢?像⼀维数组⼀样,也是使⽤⼤括号初始化的。

        类比一维数组的定义,只不过二维数组第一个常量表达式表示行,第二个常量表达式表示列

         

int arr[5][5];//创建五行五列的二维数组
char arr2[3][5];//字符型二维数组
float arr3[4][5];//浮点型二维数组

        其初始化与一维数组大致一样,都分为完全初始化和不完全初始化。

        

int arr1[3][5] = {1,2};//不完全初始化
int arr2[3][5] = {0};//不完全初始化
int arr3[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};//完全初始化
int arr4[3][5] = {{1,2},{3,4},{5,6}};//按照⾏初始化
int arr5[][5] = {1,2,3};//初始化时省略⾏,但是不能省略列
        4.2 ⼆维数组的使⽤ 

                4.2.1 ⼆维数组的下标

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

int arr[3][5] = {1,2,3,4,5, 6,7,8,9,10, 11,12,13,14,15};

        

                4.2.2 二维数组的输入和输出

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

        

int main()
{int arr[3][5] = { 1,2,3,4,5, 6,7,8,9,10, 11,12,13,14,15 };int i = 0;for(i = 0; i < 3; i++){int j = 0;for (j = 0; j < 5; j++){printf("%d", arr[i][j]);}printf("\n");}return 0;
}

        结果如下:

         

        4.2.3 ⼆维数组在内存中的存储 

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

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

        结果如下:

        

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

        

 五、数组练习

        多个字符从两端移动,向中间汇聚 编写代码,演⽰多个字符从两端移动,向中间汇聚

        分析:

        若要完成此题,需要借个操作符:strlen和函数:Sleep。

        一下是解释:

         

 C语言中的 sleep 函数可以让当前线程暂停执行一段时间,通常用于模拟实际运行环境下的等待或延时操作。在 Windows 和 Linux 等主流操作系统中,sleep 函数的实现方式略有不同,但其基本原理都是通过让线程进入睡眠状态来实现等待或延时的效果。

其中,seconds 参数表示线程需要暂停的秒数。sleep 函数返回值为 0,表示线程成功地暂停了指定的秒数,如果 sleep 函数被其他信号打断,则返回值为剩余需要暂停的秒数。

需要注意的是,sleep 函数的参数类型为 unsigned int,而不是浮点数类型。如果需要暂停小于 1 秒的时间,可以使用 usleep 函数,它的参数类型为微秒(unsigned int),可以精确地控制线程的等待时间。

        在每次输出之后,使用 sleep 函数暂停 1 秒,模拟实际运行环境下的延时操作。需要注意的是,在使用 sleep 函数时,应该将输出立即刷新到控制台上,否则可能会出现输出延迟的情况。

另外,需要注意的是,sleep 函数会让当前线程进入睡眠状态,因此在调用 sleep 函数时,应该确保当前线程已经完成了所有需要执行的操作,否则可能会导致程序出现不可预测的结果。同时,需要注意不要在循环中频繁地调用 sleep 函数,否则可能会降低程序的性能,影响程序的正常运行。

需要注意的是,在不同的操作系统中,sleep 函数的精度和可靠性可能会有所不同。在一些嵌入式系统中,sleep 函数的精度可能会受到系统时钟精度的限制,导致实际暂停的时间可能会比预期的时间短。因此,在使用 sleep 函数时,应该根据实际需要选择合适的等待时间,并且在代码中添加必要的异常处理机制,以确保程序的稳定性和可靠性。

        总的来说:strlen是计算长度的,sleep是延迟打印。 

        可参考如下代码: 

#define _CRT_SECURE_NO_WARNINGS 1​
#include <stdio.h>
int main()
{char arr1[] = "hello,world" ;char arr2[] = "###########" ;int left = 0;int right = strlen(arr2) - 1;while (left <= right){Sleep(1000);arr2[right] = arr1[right];arr2[left] = arr1[left];left++;right--;printf("%s\n", arr2);}return 0;
}

        结果如下:

         六、最后

        今天的学习到这里就结束了,如果有什么问题可以留言,我会尽我所能为你解答。

        完!

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

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

相关文章

云服务器2核4G5M配置代表什么意思?

腾讯云服务器2核4G5M带宽配置是代表什么&#xff1f;代表2核CPU、4G内存、5M公网带宽&#xff0c;这是一款轻量应用服务器&#xff0c;系统盘为60GB SSD云硬盘&#xff0c;活动页面 txybk.com/go/txy 活动打开如下图&#xff1a; 腾讯云2核4G5M服务器 如上图所示&#xff0c;这…

练习8 Web [GYCTF2020]Blacklist

这道题其实不是堆叠注入&#xff0c;但是我在联合查询无效后&#xff0c;试了一下堆叠&#xff0c;最后一步发现被过滤的sql语句太多了&#xff0c;完全没法 查阅其他wp的过程[GYCTF2020]Blacklist 1&#xff08;详细做题过程&#xff09; 是用的handler语句&#xff0c;只能用…

cmd常用指令

cmd全称Command Prompt&#xff0c;中文译为命令提示符。 命令提示符是在操作系统中&#xff0c;提示进行命令输入的一种工作提示符。 在不同的操作系统环境下&#xff0c;命令提示符各不相同。 在windows环境下&#xff0c;命令行程序为cmd.exe&#xff0c;是一个32位的命令…

【系统性】 循序渐进学C++

循序渐进学C 第一阶段&#xff1a;基础 一、环境配置 1.1.第一个程序&#xff08;基本格式&#xff09; ​ #include <iosteam> using namespace std;int main(){cout<<"hello world"<<endl;system("pause"); }​ 模板 #include &…

王道c语言ch11-单链表的新建、插入、删除例题

王道c语言ch11-单链表的新建、插入、删除例题 #include <stdio.h> #include <stdlib.h> #define END 33typedef int ElemType;typedef struct LNote {ElemType data;struct LNote *next; } LNote, *LinkList;//头插法 void list_head_insert(LinkList &L) {El…

email + celery+django 异步发送邮件功能的实现

主要流程&#xff1a; django通过发件服务器到收件服务器&#xff0c;最后到收件人 邮件配置设置需要打开SMTP/IMAP并获的授权码&#xff0c;完成授权功能实现发送给收件人 邮件配置请参考另一博客https://blog.csdn.net/qq_44238024/article/details/136277821 项目结构树…

蓝桥杯刷题(十)

1.翻转 代码 输入数据&#xff0c;每组数据进行比较&#xff0c;j的范围掐头去尾&#xff0c;若a[j]b[j]&#xff0c;继续&#xff0c;若出现010,101子串则改成000,111&#xff0c;遍历完后比较a是否等于b&#xff0c;相同则输出次数&#xff0c;不同则输出-1。 for _ in ran…

Spring Data访问Elasticsearch----Elasticsearch对象映射

Spring Data访问Elasticsearch----Elasticsearch对象映射 一、元模型(Meta Model)对象映射1.1 映射注解概述1.1.1 控制向Elasticsearch写入和从其读取哪些属性1.1.2 日期格式映射1.1.3 Range类型1.1.4 映射的字段名1.1.5 Non-field-backed属性1.1.6 其他属性注解 1.2 映射规则1…

探索Darknet:快速学习Darknet的经验和技巧

Darknet是一个流行的深度学习框架&#xff0c;广泛用于实现各种神经网络模型&#xff0c;特别是用于目标检测和图像识别任务。在本文中&#xff0c;我将分享一些学习Darknet的经验和技巧&#xff0c;帮助你快速入门和掌握这个强大的工具。 1. 了解Darknet的背景 在开始学习Dar…

JavaWeb:vue、AJax、ELement、maven、SpringBoot、、Http、Tomcat、请求响应、分层解耦

1 Vue 1.1 Vue介绍 VUE是前端框架&#xff0c;基于MVVM&#xff0c;实现数据双向绑定 框架是半基础软件&#xff0c;可重用的代码模型 1.2 Vue指令 <script src"js/vue.js"></script></head> <body><div id"id"><!--…

Custom GPTs Are Here and Will Impact Everything AI

定制GPT时代来临&#xff0c;将深刻影响人工智能领域 摘要 OpenAI最新推出的定制GPT标志着个性化数字助手的全新纪元&#xff0c;将ChatGPT的强大能力应用于满足个人和专业的需求。本文将探讨定制GPT的核心特点、应用场景、安全性保障以及其对人工智能未来的影响。 定制GPT的…

Keras库搭建神经网络

Keras并非简单的神经网络库&#xff0c;而是一个基于Theano的强大的深度学习库&#xff0c;利用它不仅仅可以搭建普通的神经网络&#xff0c;还可以搭建各种深度学习模型&#xff0c;如自编码器、循环神经网络、递归神经网络、卷积神经网络等。 安装代码&#xff1a; pip ins…

Docker Mysql无root账户创建最高权限用户

创建最高权限用户 进入 MySQL 容器的命令行界面。您可以使用以下命令&#xff1a; 修改配置文件my.cnf 无密码进入 [mysqld]下输入 skip-grant-tables重启mysql容器 进入容器内部 container_name 容器ID或name docker restart mysql docker exec -it <container_name>…

Kubectl常用命令

管理资源&#xff08;查看、创建、更新、删除&#xff09; 查看node资源 kubectl get nodes查看命名空间 kubectl get ns查看service资源 -n 指明所属的命名空间&#xff0c;不写默认看命名空间为default下的所有service kubectl get svc -n default查看pod资源 -n 指明所…

fpga_图像处理

一 fpga图像处理的基本原理 fpga图像处理的基本原理是将图像数据转换为数字信号&#xff0c;并通过fpga实现各种图像处理算法和技术。图像数据可以通过各种传感器和摄像头获得&#xff0c;然后通过模数转换器(ADC)将其转换为数字信号&#xff0c;数字信息可以通过fpga的输入输出…

tcpudp面试题

什么是IP地址 ip地址是主机在网络中的唯一标识&#xff0c;当主机更换网络时ip号会改变。 ip网络号主机号&#xff08;A类网、B类网、C类网、D类网、E类网&#xff09;tcp和udp的区别 tcp&#xff1a; 1、提供面向链接的&#xff0c;可靠的数据传输服务&#xff0c; 2、稳定&am…

线性代数笔记20--特征值特征向量与旋转矩阵推导

1. 特征向量与特征值 研究对象是一个平面 A A A&#xff0c;向量 X X X通过 A A A变换后仍然平行于 X X X。 这样的向量就叫特征向量。 变换后的向量与原向量的比值就是特征值。 A X / / X A X λ X AX \mathop{//} X\\ AX \lambda X AX//XAXλX 如果矩阵 A A A是奇异矩阵&…

【计算机网络】基本概念

基本概念 IP 地址端口号协议协议分层封装分用客户端服务器请求和响应两台主机之间的网络通信流程 IP 地址 概念&#xff1a;IP 地址主要是用于唯一标识网络主机、其他网络设备&#xff08;如路由器&#xff09;的网络地址。简单来说&#xff0c;IP地址用来唯一定位主机。格式&…

网络安全之DDos攻击原理与防御

DDos简介 对于DDos(分布式拒绝服务)攻击&#xff0c;人们往往谈虎色变。它被认为是安全领域中最难解决的问题之一&#xff0c;迄今为止也没有完美的解决方案。DDos攻击是一种网络攻击方式&#xff0c;其目的是通过利用大量的互联网连接设备同时向目标网站或服务发送大量请求&a…

软件架构设计 C/S与B/S架构的区别

一、什么是C/S架构&#xff1f; C/S是Client/Server的缩写。服务器通常采用高性能的PC、工作站或小型机&#xff0c;并采用大型数据库系统&#xff0c;如Oracle或SQLServer。 C/S架构软件有一个特点&#xff0c;就是如果用户要使用的话&#xff0c;需要下载一个客户端&#x…