【C生万物】数组

news2025/1/13 15:35:27

C语言

📚博客主页:爱敲代码的小杨.

✨专栏:《Java SE语法》 | 《数据结构与算法》 | 《C生万物》

❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️

🙏小杨水平有限,欢迎各位大佬指点,相互学习进步!

文章目录

  • 1.数组的概念
  • 2.数组的创建和初始化
    • 2.1数组的创建
    • 2.2 数组的初始化
    • 2.3 指示器
    • 2.4 数组的类型
  • 3.数组的使用
    • 3.1 数组的下标
    • 3.2 数组元素的打印
    • 3.3 数组的输入
  • 4.数组在内存中的存储
  • 5.sizeof 计算数组元素个数
  • 6.二维数组的创建
    • 6.1 二维数组的概念
    • 6.2 二维数组的创建
  • 7.二维数组的初始化
    • 7.1 不完全初始化
    • 7.2 完全初始化
    • 7.3 按照行初始化
    • 7.4 初始化时可以省略行,但是不能省略列
  • 8. 二维数组的使用
    • 8.1 二维数组的下标
    • 8.2 二维数组的输入和输出
  • 9.二维数组在内存中的存储

1.数组的概念

数组的定义:数组就是一组相同类型元素的集合

  • 数组中存放的是1个或者多个数据,但是数组元素个数不能为0。
  • 数组中存放的多个数据,类型是相同的。

2.数组的创建和初始化

2.1数组的创建

数组的基本语句:

type arr_name[常量值];

存放在数组的值被称为数组元素,数组在创建的时候可以指定数组的大小数组的元素类型。

  • type指定的是数组中存储的数据类型。
  • arr_name指的是数组名的的名字。
  • []的中常量值用来指定数组大小的。

举例:

  1. 我们想存储20个人的成绩,就可以用数组
int cj[20];
  1. 也可以创建其他类型的数组
char ch[10];
float score[10];

2.2 数组的初始化

像其他变量一样,数组的也可以在声明时获得一个初始值。
数组的初始化器最常见的格式是用一个花括号括起来的常量表达式列表,常量表达式之间用逗号隔开

// 完全初始化
int a1[10] = {1,2,3,4,5,6,7,8,9,10};

// 不完全初始化
int a2[10] = {1};// 第一个元素初始化为1,其他的元素默认初始化为0

// 错误的初始化 - 初始化项太多
int a[3] = {1,2,3,4};

2.3 指示器

数组中只有相对较少的元素需要进行显式的初始化,而其他元素可以进行默认赋值。
例子:

int a[10] = {0, 0, 10, 0, 0, 0, 18, 0, 9, 0 };

希望元素2为10,元素6为18,元素8为9,而其他元素为0。对于大数组,如果使用这种方式赋值,将是冗长和容易出错的(想象一下两个非0元素之间有200个0的情况)。
C99 中指示器可以用于解决这一问题。上面的例子可以用指示器写为:

int a[10] = {[2] = 10, [6] = 18, [9] = 9};

方括号和其中的常量表达式一起,组成了一个指示器。
除了可以是赋值变得更简短、更易读之外,指示器还有一个优点:赋值的顺序不再是一个问题,我们也可以将先前的例子重写为:

int a[10] = {[9] = 9, [6] = 18, [2] = 10};

组成指示器的方括号里必须是整型常量表达式。

2.4 数组的类型

数组也是有类型的,数组算是一种自定义类型,去掉数组名留下的就是数组的类型
如下:

int arr1[10];
int arr2[20];

char ch[10];

arr1数组的类型是int [10]
arr2数组的类型是int [20]
ch数组的类型是char [5]

3.数组的使用

学习了数组基本语法,数组可以存储数据,存放数据的目的是对数据的操作。

3.1 数组的下标

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

int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};

image.png
在C语言中数组的访问提供了一个操作符[],这个操作符叫:下标引用操作符
有了下标引用操作符,我们就可以访问数组的元素了,比如我们要访问下标为7的元素,我们就可以使用arr[7],想要访问下标为3的元素,我们就可以使用arr[3],如下代码:

#include<stdio.h>

int main()
{
	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };

	printf("%d\n", arr[7]);// 8
	printf("%d\n", arr[3]);// 4

	return 0;
}

运行结果:
image.png

3.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;
}

运行结果:
image.png

3.3 数组的输入

明白了数组的访问,当然我们也根据需求,自己给数组输入想要的数据。
代码:

#include<stdio.h>

int main()
{
	int arr[10];
	int i = 0;
	printf("请输入数组元素:\n");
	for (i = 0; i < 10; i++)
	{
		scanf("%d", &arr[i]);
	}

	printf("元素如下:\n");
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr[i]);
	}

	return 0;
}

运行结果:
image.png

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;
}

运行结果:
image.png
image.png
从输出的结果我们分析,数组随着下标的增长,地址是由小到大变化的,并且我们发现每两个相邻的元素之间相差4(因为一个整型是4个字节)。所以我们得出结论:数组在内存中是连续存放的

5.sizeof 计算数组元素个数

运算符sizeof可以确定数组的大小(字节数)。如果数组a有10个整数,那么sizeof(a)通常为40(假定每个整数占4字节)。
还可以用sizeof来计算数组元素的大小。用数组的大小除以数组元素的大小可以得到数组的长度:

sizeof(a) / sizeof(a[0])

当需要数组长度时,我们可以采用上述表达式。
例如,数组a的清零操作可以写成如下形式:

for(i = 0; i < sizeof(a) / sizeof(a[0]); i++)
    a[i] = 0;

如果使用这种方法,即使数组长度会改变,也不需要改变循环。

6.二维数组的创建

6.1 二维数组的概念

前面学习的数组被称为一维数组,数组的元素都是内置类型,如果我们把一维数组作为数组的元素,这时候就是二维数组,二维数组作为数组元素的数组被称为三维数组,二维数组以上的数组统称为多维数组
image.png

6.2 二维数组的创建

那我们如何定义二维数组呢?语法如下:

type arr_name[常量值1][常量值2];

// 例如:
int arr[3][5];
double data[2][8];

解释:上述代码中出现的信息

  • 3表达数组有3行
  • 5表示每一行有5个元素
  • int 表达数组的每个元素时整型类型
  • arr 是数组名,可以根据自己的需要指定名字

7.二维数组的初始化

通过嵌套一维数组初始化器的方法可以产生二维数组的初始化器。

7.1 不完全初始化

int arr1[3][4] = {1,2};
int arr2[3][5] = {0};

image.png

7.2 完全初始化

int arr3[3][5] = {1,2,3,4,5, 2,3,4,5,6,7, 3,4,5,6,7};

image.png

7.3 按照行初始化

int arr4[3][5] = {{1,2},{3,4},{5,6}};

image.png

7.4 初始化时可以省略行,但是不能省略列

int arr5[][5] = {1,2};
int arr6[][5] = {1,2,3,4,5,6,7};
int arr7[][5] = {{1,2},{3,4},{5,6}};

image.png

8. 二维数组的使用

8.1 二维数组的下标

访问二维数组也是使用下标的形式的,二维数组是有行和列的,只要锁定行和列就能锁定数组中的一个元素。
C语言规定,二维数组的行和列都是从0开始的,如下所示:

int arr[3][5]={1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};

image.png
图中最左侧绿色的数字表示行号,第一行蓝色的数字表示列号,都是从0开始的,比如:我要找第2行,第4列的元素:

#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 ", arr[2][4]);// 7

	return 0;
}

运行结果:
image.png

8.2 二维数组的输入和输出

我们只要能够按照一定的规律残生所以的行和列的数字就行,我们可以借助循环实现生成所有的下标。

#include<stdio.h>

int main()
{
	int arr[3][5];
	int i = 0; // 遍历行
	int j = 0; // 遍历列

	// 输入数据
	printf("请输入数组元素:\n");
	for (i = 0; i < 3; i++) // 产生行号
	{
		for (j = 0; j < 5; j++) // 产生列号
		{
			scanf("%d", &arr[i][j]); // 输入数据
		}
	}

	// 输出数据
	printf("数组元素如下:\n");
	for (i = 0; i < 3; i++) // 产生行号
	{
		for (j = 0; j < 5; j++) // 产生列号
		{
			printf("%d ", arr[i][j]); // 输出数据
		}
		printf("\n");
	}

	return 0;
}

运行结果:
image.png

9.二维数组在内存中的存储

像一维数组一样,我们想知道二位数组在内存中的存储方式,我们也是可以打印出数组所有元素的地址。

#include<stdio.h>

int main()
{
	int arr[3][5] = { 0 };
	int i = 0;
	int j = 0;
	for (i = 0; i < 3; i++)
	{
		for (j = 0; j < 5; j++)
		{
			printf("&arr[%d][%d] = %p\n", i, j, &arr[i][j]);
		}
	}

	return 0;
}

运行结果:
image.png
image.png
从输入的结果来看,每一行内部的每个元素都是相邻的,地址之间相差4个字节,跨行位置处的两个元素之间也是差4个字节,所有二维数组中的每一个元素都是连续存放的。

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

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

相关文章

node.js基础-02

Author nodes&#xff1a;&#xff08;题记&#xff09; Hypertest Transfer protocol is very important to programming personnel。it doesnt matter if youre a front-end engineer or a back-end engineer.So,lets study it together. http协议对于编程工程师很重要&am…

python coding with ChatGPT 打卡第19天| 二叉树:合并二叉树

相关推荐 python coding with ChatGPT 打卡第12天| 二叉树&#xff1a;理论基础 python coding with ChatGPT 打卡第13天| 二叉树的深度优先遍历 python coding with ChatGPT 打卡第14天| 二叉树的广度优先遍历 python coding with ChatGPT 打卡第15天| 二叉树&#xff1a;翻转…

【C++】实现一个二叉搜索树

目录 二叉搜索树的概念 1.结点定义 2.构造、析构、拷贝构造、赋值重载 3.插入、删除、查找、排序 3.1插入 3.2插入递归版 3.3查找指定值 3.3查找指定值递归版 3.4中序遍历 3.5删除 最后 二叉搜索树的概念 二叉搜索树又称为二叉排序树或二叉查找树&#xff0c;它或者…

python WEB接口自动化测试之requests库详解

由于web接口自动化测试需要用到python的第三方库--requests库&#xff0c;运用requests库可以模拟发送http请求&#xff0c;再结合unittest测试框架&#xff0c;就能完成web接口自动化测试。 所以笔者今天先来总结一下requests库的用法。希望对大家&#xff08;尤其是新手&…

使用CICFlowMeter 实现对pcap文件的特征提取【教程】

使用CICFlowMeter 实现对pcap文件的特征提取【教程】 针对现有的关于CICFlowMeter 的使用教程不够全面&#xff0c;一些细节没有展示&#xff0c;我将结合网络上的相关资料和实际的经历&#xff0c;提供一些经验和建议。 configuration information --------------- Windows…

hexo部署到gitee(码云)

引言 Hexo 是一个基于Node.js的静态博客框架&#xff0c;而 Gitee&#xff08;也被称为码云&#xff09;是一个国内的代码托管平台&#xff0c;支持 Git 版本控制系统&#xff0c;与 GitHub 类似。将 Hexo 部署到 Gitee Pages 可以让你的博客受益于 Gitee 的国内服务器&#xf…

详解计算机软件基本概念

软件基本概念 软件的定义 一个完整的计算机系统是由硬件系统和软件系统协同工作来完成某一给定的任务的。 只有硬件的计算机称为裸机&#xff0c;裸机必须安装了计算机软件后才可以完成各项任务。 从广义地讲&#xff0c;软件是指计算机程序、数据以及开发、使用和维护程序…

Go语言安全编码:crypto/sha1库全面解析

Go语言安全编码&#xff1a;crypto/sha1库全面解析 简介SHA-1基础原理和特点SHA-1与其他哈希算法的比较代码示例&#xff1a;基本的SHA-1哈希生成 使用crypto/sha1处理数据处理字符串和文件的SHA-1哈希代码示例&#xff1a;为文件生成SHA-1哈希 常见错误和最佳实践 在实际项目中…

烟雨要饭网带后台,附带搭建教程

直接上传访问即可&#xff0c;有安装向导&#xff0c;php环境不得低于7.0 后台地址/Admin&#xff0c;默认账号admin 默认密码123456 自带乞讨音乐&#xff0c;增加樱花特效

《乱弹篇(十二)聊春晚》

龙年大初一&#xff0c;老龄笔者发表《乱弹篇&#xff08;十二&#xff09;》。“十二”的标志&#xff0c;乃好事成双“二”。喜庆有余&#xff0c;自不待言&#xff01; 除夕夜我没有看春晚&#xff0c;是在继续追剧&#xff0c;即以明朝宫廷内斗为背景的电视连续剧《后宫》…

【原理图PCB专题】Cadence17.4版本新增加的Cutout和Design_Outline层有什么用?

在Cadence 17.4版本中我们发现在Board Geometry下面多出了Cutout和Design_Outline两层,其实这两层在高版本的软件中都做为板框使用。 如下所示在输出光绘时,如果没有将Cutout和Desing_Outline两层加入,还是使用16版本的Outline来定义板框的话,在出光绘时会提示:WA…

备战蓝桥杯---搜索(进阶1)

话不多说&#xff0c;直接看题&#xff1a; 没有传送带时&#xff0c;我们可以直接BFS&#xff0c;但因为传送带的出现&#xff0c;可能在队列里的元素到起点时间不单调的问题&#xff0c;而BFS本来就是可以看成随着时间推移而产生的情况&#xff0c;于是我们把队列看成优先队列…

Matlab使用点云工具箱进行点云配准ICP\NDT\CPD

一、代码 主代码main.m&#xff0c;三种配准方法任选其一 % 读取点云文件 source_pc pcread(bun_zipper.ply); target_pc pcread(bun_zipper2.ply);% 下采样 ptCloudA point_downsample(source_pc); ptCloudB point_downsample(target_pc);% 配准参数设置 opt param_set…

有关网络安全的课程学习网页

1.思科网络学院 免费学习skillsforall的课程 课程链接&#xff1a;Introduction to Cybersecurity by Cisco: Free Online Course (skillsforall.com) 2.斯坦福大学计算机和网络安全基础 该证书对于初学者来说最有价值&#xff0c;它由最著名的大学之一斯坦福大学提供。您可…

卫星通讯领域FPGA关注技术:算法和图像方面(1)

最近关注的公众号提到了从事移动通信、卫星通讯等领域的FPGA、ASIC、信号处理算法等工程师可能需要关注的技术&#xff0c;有LMS算法、RLS算法、LCMV算法、SAR图像处理&#xff0c;以下做了一些基础的调研&#xff1a; 1 LMS算法&#xff1a; LMS&#xff08;Least Mean Squa…

springboot170图书电子商务网站的设计与实现

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…

elasticsearch下载及可视化工具下载使用

elasticsearch下载及配置、启动 一、下载 Download Elasticsearch | Elastic 二、启动 双击bat即可。 出现如下说明启动成功&#xff1a; 访问测试&#xff1a; 三、注意 &#xff08;1&#xff09;因为es启动默认端口是&#xff1a;9200,所以需要检查此端口是否被占用。…

unity-ios-解决内购商品在Appstore上面已配置,但在手机测试时却无法显示的问题

自己这几天用 unity 2021 xcode 14.2 开发ios内购&#xff0c;appstore上面内购商品都已经配置好了&#xff0c;但是在手机里就是不显示&#xff0c;最后才发现必需得满足以下条件才行&#xff1a; 1. Appstore后台 -> 内购商品 -> 商品状态必需为『准备提交』以上状态…

【万题详解】洛谷P1282 多米诺骨牌

题目 链接——题目在这里&#xff01;&#xff01;&#xff01; 多米诺骨牌由上下 22 个方块组成&#xff0c;每个方块中有 1∼6 个点。现有排成行的上方块中点数之和记为 S1​&#xff0c;下方块中点数之和记为 S2​&#xff0c;它们的差为 ∣∣S1​−S2​。如图S161119&…

最佳视频转换器软件:2024年视频格式转换的选择

我们生活在一个充满数字视频的世界&#xff0c;但提供的内容远不止您最喜欢的流媒体服务目录。虽然我们深受喜爱的设备在播放各种自制和下载的视频文件方面变得越来越好&#xff0c;但在很多情况下您都需要从一种格式转换为另一种格式。 经过大量测试&#xff0c; 我们尝试过…