二维数组---C语言(行列抽象思维)

news2024/10/6 16:20:08

目录

前言:

1.数组

1.1数组的初始化

1.2数组的访问方法

2.二维数组

2.1二维数组的创建和初始化

2.2二维数组的访问

2.3内存中的二维数组


❤博主CSDN:啊苏要学习

  ▶专栏分类:C语言◀

  C语言的学习,是为我们今后学习其它语言打好基础,C生万物!

  开始我们的C语言之旅吧!✈


前言:

  在学习完函数一章,我们接着来学习C语言中很重要的表示数据的一种形式---数组。

1.数组

  数组,顾名思义就是一组数据的集合,数据里的元素有一个共同特征,那就是同属于一种数据类型

  当我们想要使用多个整型的时候,一个一个整型变量的创建是比较麻烦的。比如:

int main()
{
    int a = 0;
    int b = 0;
    int c = 0;
    int d = 0;
    int e = 0;
    return 0;
}

  这样不仅代码看上去很长,而且也不好看。我们创建数组来表示同一种数据类型的多个值

int main()
{
    //创建一个整型数组,数组有五个元素,每个元素是整型。
    int arr[5] = {1,2,3,4,5};
    return 0;
}

1.1数组的初始化

  数组的初始化,大家可能要问,为什么要初始化?我一开始也不知道要给数组初始化什么值,这里我想告诉大家的是:不知道初始化什么值没关系,我们给它初始化个0就好了嘛,至少我们还知道这个数组里的值是0如果没有进行初始化,那数组里的值将会是随机值(俗称垃圾值),所以我们养成初始化的好习惯是有必要的

  • 完全初始化
int main()
{
    //完全初始化,将每个元素都初始化到了
    int arr[5] = {1,2,3,4,5};//初始化的时候,用{}括住,给数组的对应元素赋值
    //第一个元素初始化为1,第二个元素初始化为2,依次类推
    return 0;
}
  • 未完全初始化
#include <stdio.h>

int main()
{
    //只有第一个元素被初始化为了0
    int arr[5] = {0};
    //注意:数组未完全初始化,编译器会自动给数组没有初始化的元素初始化为0
    //所以这个数组第一个元素是我们初始为0,剩下的四个元素是编译器初始化为0
    return 0;
}

  元素个数可以省略,但初始化内容一定要写,元素个数会根据初始化内容定;初始化可以内容省略,但元素个数一定要写,此时相当于没有初始化数组

1.2数组的访问方法

  现在我们已经会创建数组了,那如何使用数组呢?我们引入下标操作符来访问数组中的元素。

  arr[0]是数组的首元素数据1,这里的知识点是数组的下标从0开始,arr[6]等于7,元素7的下标是6我们仔细观察,数组一共有7个元素:1、2、3.......,然后最后一个元素的下标是元素个数减1

  计算元素个数的方法:数组的大小/数组一个元素的大小

  一个整型的占用的空间是4个字节,数组里有7个元素,所以整个数组的大小是28个字节

  我们思考着:一个整型是4个字节,7个整型算起来是28个字节。那是不是说明在这个数组的中间没有其它未被利用的空间呢?也就是说,数组里的每个元素都是连在一起的,一个元素挨着一个元素。如果一个元素与另一个元素之间有空间未被使用,那数组占用的空间大小肯定不止28咯

  是的,数组还有一个特点,数组里的元素是连续存放的我们知道每个内存单元都有一个地址编号,一个内存单元是1个字节的大小,我们不妨打印数组所有元素的地址出来看看是不是一串连续的地址编号

  &是取地址操作符,%p第打印地址的格式设置我们看到首元素的地址是98,说明第一个元素的地址是从98开始,以及后面的99、9A、9B这四个内存单元存放一个整型(四个字节大小,每个内存单元一个字节),第二个元素arr[1]的地址开始是9C,恰好衔接着前一个整型元素的后面,后面的其它元素都是这种情况

  arr[1]存放在9C、9D、9E、9F这四个内存单元中,很明显,数组元素是连续存储的

2.二维数组

  二维数组,其实就是以一维数组为数组元素的一个一维数组。看完下面的内容后,相信读者会感悟到二维数组的多种理解方式的。

2.1二维数组的创建和初始化

  • 完全初始化
int main()
{
    //创建了一个3行4列的二维数组
    int arr[3][4] = {{1,2,3,4},{2,3,4,5},{3,4,5,6}};
    //完全初始化,十二个元素都有初始化
    return 0;
}

  • 未全初始化
int main()
{
    int arr[][3] = {{1,2},{1,3},{4,5,6}};
    //二维数组可以省略数组的行数,但列数不能省略。
    //函数会根据初始化内容自动计算的。
    return 0;
}

  第一行、第二行我们只初始化了两列,第三列没有初始化只要有初始化,未被初始化的余下的元素都会被编译器初始化为0

2.2二维数组的访问

  和一维数组一样,访问二维数组也是用下标的方式,我们来看下面的代码吧~

 

  当i等于0的时候,随着j从0到3增长(因为j<4,最多到3),打印出一行。是arr[0]这一行的所有元素,j的for循环遍历完后,i++来到arr[1]也就是第二行,这一就能遍历所有元素了。

  对于二维数组,行和列的下标也都是从0开始的。

  我们前面说到,arr是一个存放一维数组的一个数组,那么arr[0]表示二维数组的首元素,也就是arr[0]这一行数组,arr[0][0]表示第一行数组的第一个元素

  补充:数组名[下标]访问元素,那么这里arr[0]我们就可以理解成第一行数据的数组名,我们可以使用数组名arr[0],再加下标访问这个数组里的元素。arr[0][0]、arr[0][1]、arr[0][2]、arr[0][3]这样子。

  总结:二维数组的元素是一维数组,一维数组里的元素个数与列相同;也可以这样理解int arr[3][4],arr[3]表明这个数组有三个元素,每个元素的类型是int[4]这样的一个一维数组,int a[5];这样的a数组,类型是int[5]。

  以上是行列式的理解,我们看看二维数组在内存中真正存储的样子。

2.3内存中的二维数组

   数组的初始化可以直接罗列出来,1、2、3这三个元素放满第一行后就会到第二行上放数据

  看到第一行元素的地址,与第二行元素的地址都是紧紧凑在一块的。我们知道,它在内存中,也是连续存储也,不像是我们所说的行和列的样子,实际上应是下面这个样子:

  这些行不像我们想象的那样分一行一行的是一条直线存储着的,但我们可以用行列式理解二维数组是完全没问题的。

  遍历二维数组的时候,通过需要用两层for循环,一层表示行,一层表示列,在行不变的情况下,让列走完,然后行+1,再让列走完这一行,直到达到条件。

  补充:为什么省略行可以,而省略列不行,我们可以从两个角度来理解:第一就是我们在创建一个数组的时候,这个数组的元素类型要明确,不能是不清楚的,比如int arr[][4],int[4]是数组的元素类型,一个元素占用四个整型的空间大小,有多少个元素我根据初始化内容定,和一维数组一样int arr[] = {1,2,3};第二就是当我们省略行的时候,并没有影响一次开辟行空间的大小,影响一行开辟空间大小的是列。当列为整型二维数组列为4,一行就是16个字节,为5,一行就为20个字节

  到这里数组的最最最简单的内容就讲完啦,下面我们将使用数组的知识,搞个三子棋和扫雷小游戏,敬请期待~


结语:希望读者读完有所收获!在学C的路上,祝福我们能越来越C!✔

  读者对本文不理解的地方,或是发现文章在内容上有误等,请在下方评论区留言告诉博主哟~,也可以对博主提出一些文章改进的建议,感激不尽!最后的最后!

  ❤求点赞,求关注,你的点赞是我更新的动力,一起努力进步吧。

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

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

相关文章

探索 Elasticsearch 8.X Terms Set 检索的应用与原理

1、Terms Set 检索简介 Terms Set查询是Elasticsearch中一种强大的查询类型&#xff0c;主要用于处理多值字段中的文档匹配。 其核心功能在于&#xff0c;它可以检索至少匹配一定数量给定词项的文档&#xff0c;其中匹配的数量可以是固定值&#xff0c;也可以是基于另一个字段的…

快速排序、希尔排序、归并排序、堆排序、插入排序、冒泡排序、选择排序(递归、非递归)C语言详解

1.排序的概念及其运用 1.1排序的概念 排序&#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作。 稳定性&#xff1a;假定在待排序的记录序列中&#xff0c;存在多个具有相同的关键字的记录&…

postman 的 console 窗口,助力 http 请求错误时的问题排查

postman 是个很不错的 http 请求测试工具&#xff0c;有时我们使用它发送 http 请求&#xff0c;但是因为各种原因&#xff0c;导致请求失败&#xff0c;没有 response 返回&#xff0c;可能只有一个状态码&#xff0c;这让我们排查起来非常困难&#xff0c;比如下图所示&#…

GitLab + Jenkins 实现持续集成CI

1 软件版本 2 基础环境安装 2.1 docker 安装 yum install -y docker-ce-20.10.16 systemctl start docker && systemctl enable docker docker version 2.2 docker-compose 安装 curl -L https://get.daocloud.io/docker/compose/releases/download/1.29.2/docker-c…

虚拟化无法开启

虚拟化无法开启 开启虚拟机&#xff0c;突然出现以下报错&#xff1a; 此主机支持 Intel VT-x&#xff0c;但 Intel VT-x 处于禁用状态。 如果已在 BIOS/固件设置中禁用 Intel VT-x&#xff0c;或主机自更改此设置后从未重新启动&#xff0c;则 Intel VT-x 可能被禁用。 (1…

modbus 协议地址

modbus 仿真软件 modbus slave: 用作 modbus 服务器(也叫做modbus从站), 通常用于仿真PLC设备.modbus poll: 用作 modbus 客户端(也叫做modbus主站), 用于仿真上位机程序, 通常使用它在现场验证PLC设备的modbus通讯是否OK 理解 modbus 寻址 modbus 分4个数据区, 实际因为第4区可…

【Redis】Redis 高性能IO模型原理

前言 在面试的时候遇到Redis肯定会问&#xff0c;Redis单线程为什么那么快呀&#xff1f;你可以说下你对IO多路复用的机制嘛。但是仔细一想Redis真的是单线程在运行处理嘛&#xff0c;其实这个单线程主要指的Redis的网络IO和键值对读写是由一个线程来完成的&#xff0c;Redis在…

深度学习—卷积神经网络简单理论及实践

卷积神经网络 传统意义上的多层神经网络只有输入层、隐藏层和输出层。其中隐藏层的层数根据需要而定&#xff0c;没有明确的理论推导来说明到底多少层合适。 卷积神经网络CNN&#xff0c;在原来多层神经网络的基础上&#xff0c;加入了更加有效的特征学习部分&#xff0c;具…

Docker 安装 elasticsearch、kibana、ik

一、安装elasticsearch 1. 拉取 elasticsearch 镜像 docker pull elasticsearch:7.6.2 2. 创建 elasticsearch 容器 docker run --name elasticsearch7.6.2 -d -e ES_JAVA_OPTS"-Xms512m -Xmx512m" --net host -e "discovery.typesingle-node" -p 92…

SpringCloud踩坑系列:Mybatis的Mapper报错

500错误&#xff0c; 报错信息如下&#xff1a; org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): org.cyf.serviceDriverUser.mapper.DriverUserMapper.select1 at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(M…

判断两个时间段是否有交集

判断两个时间段是否有交集 前言&#xff1a;项目中遇到了类似会议室预约的时间段被占用&#xff0c;预约车辆时间段被占用等。 start&#xff1a;预约开始时间。 end&#xff1a;预约结束时间。 思考&#x1f914;&#xff1a; 那几种情况&#xff0c;可以正常预约&#x…

部署harbor私有镜像仓库

环境&#xff1a;所有机器都是centos7.4 一、部署harbor镜像仓库 机器IP&#xff1a;10.0.0.9 harbor服务器 1.下载harbor压缩包到服务器/root目录下[rootharbor~]#wget https://ghproxy.com/https://github.com/goharbor/harbor/releases/download/v2.5.3/harbor-offline-i…

【云计算•云原生】7.play with kubernetes在线实验环境

文章目录 1.play with kubernetes介绍2.搭建多节点nginx示例 1.play with kubernetes介绍 play with kubernetes网站链接 https://labs.play-with-k8s.com/每次登录提供4小时在线实验环境&#xff0c;最多可以开5个节点 2.搭建多节点nginx示例 点击左边的ADD NEW INSTANCE之…

网络路径下倾斜模型生产流程-倾斜生产

网络路径下倾斜模型生产流程-倾斜生产 全部控制点完成刺点后&#xff0c;检查无误后&#xff0c;点击Submit aerotriangulation。 选择使用控制点进行空三。 此时&#xff0c;将影像色彩平衡设置为Enabled&#xff0c;Position和Rotation设置为Compute。点击Submit开始空三。 …

知识管理工具,你选择语雀、Baklib、Notion还是FlowUs?

随着信息技术的不断发展&#xff0c;人们对于笔记软件的需求也越来越高。笔记软件可以帮助我们记录生活中的点滴&#xff0c;整理工作中的思路&#xff0c;提高工作效率和生活品质。然而&#xff0c;市面上的笔记软件种类繁多&#xff0c;选择一款适合自己使用的笔记软件也成为…

国产仪器 1763卫星帆板电源阵列模拟器

1763卫星帆板电源阵列模拟器用于解决卫星电源系统研制、航天器模拟供电系统测试等帆板电源阵列及二次供电设备的测量和分析&#xff0c;解决电源分系统功能验证、现场试验等无法使用真实的帆板电源等带来的难题&#xff0c;用于卫星或卫星测试系统以及太阳能逆变器中模拟太阳电…

【数据结构】Treap树堆

Treap树堆 Treap是一种平衡化二叉搜索树&#xff0c;在键值key满足二叉搜索树的前提下&#xff0c;增加了priority是满足堆序的条件。可以证明&#xff0c;如果priority的随机的&#xff0c;那么Treap的期望深度是 O ( l o g N ) O(logN) O(logN)&#xff0c;也就是说大部分操…

29从零开始学Java之如何正确创建Java里的类?

作者&#xff1a;孙玉昌&#xff0c;昵称【一一哥】&#xff0c;另外【壹壹哥】也是我哦 千锋教育高级教研员、CSDN博客专家、万粉博主、阿里云专家博主、掘金优质作者 前言 在上一篇文章中&#xff0c;壹哥给大家介绍了面向对象和面向过程的概念&#xff0c;并介绍了两者的区…

【MySQL】数据库的基本操作三:增删改查进阶

目录 &#x1f31f;一、数据库约束 &#x1f308;1、Null约束&#xff1a;创建表时&#xff0c;可以指定某列不能为空。 &#x1f308;2、Unique约束&#xff1a;唯一约束 &#x1f308;3、Default约束&#xff1a;默认值约束 &#x1f308;4、Primary Key&#xff1a;主键…

@RefreshScope 动态刷新机制

前言 一般在项目中&#xff0c;我们集成Nacos做统一配置管理&#xff0c;同时配置支持动态刷新&#xff0c;项目中都会用到RefreshScope注解&#xff0c;这里和大家一起看看RefreshScope实现动态刷新的原理。 Scope注解 RefreshScope 能实现动态刷新全仰仗着Scope 这个注解&…