首页 > 其他分享 >c语言--数组详解

c语言--数组详解

时间:2024-07-24 22:28:00浏览次数:12  
标签:初始化 arr 10 -- 元素 int 详解 数组

数组的概念

数组是一组相同类型元素的集合;从这个概念我们就可以发现2个有价值的信息:

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

数组分为一维数组和多维数组,多维数组一般比较多见的是二维数组。

一维数组

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

1.1数组的创建

一维数组的基本语法如下:

type arr_name[常量值];

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

  • type 指定的是数组中存放数据的类型,可以是: char、short、int、float 等,也可以自定义的类型。
  • arr_name 指的是数组名的名字,这个名字根据实际情况,起的有意义就行。
  •  [ ] 中的常量值是用来指定数组的大小的,这个数组的大小是根据实际的需求指定就行。

例如:

int arr[10];
char ch[8];
double match[20];

 1.2 数组的初始化

有时候,数组在创建的时候,我们需要给定⼀些初始值,这种就称为初始化。

一般情况下,数组的初始化使用大括号,将数据放在大括号内。

//完全初始化
int arr[5] = {1,2,3,4,5}; 

//不完全初始化
int arr2[6] = {1};    //第⼀个元素初始化为1,剩余的元素默认初始化为0     

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

//数组如果初始化了,就可以省略数组的大小,那么编译器会根据初始化的能容来自动推算出数组元素的个数
int arr3[] = {1,2,3}

有时会使用循环来初始化

int i;
int arr[5];
for(i=0;i<5;i++)
{
    scanf("%d",&arr);
}

1.3 数组的类型

数组也是有类型的,数组算是⼀种⾃定义类型,去掉数组名留下的就是数组的类型。

如下:

int arr[10];
char ch[8];
double match[20];
  • arr数组类型是 int [10]
  • ch数组类型是 char [8]
  • match数组类型是 double [20]

2.一维数组的使用 

学习了⼀维数组的基本语法,⼀维数组可以存放数据,存放数据的目的是对数据的操作,那我们如何使用⼀维数组呢?

2.1一维数组的下标

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

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

在C语言中数组的访问提供了⼀个操作符 [ ] ,这个操作符叫:下标引用操作符。 有了下标访问操作符,我们就可以轻松的访问到数组的元素了,比如我们访问下标为0的元素,我们就可以使用 arr[0] ,想要访问下标是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[0]);//1
 printf("%d\n", arr[3]);//4

 return 0;
}

 2.2一维数组在内存中的储存

有了前⾯的知识,我们其实使用数组基本没有什么障碍了,如果我们要深⼊了解数组,我们最好能了解⼀下数组在内存中的存储。

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

输出结果是:

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

sizeof 计算数组个数

在遍历数组的时候,我们经常想知道数组的元素个数,那C语言中有办法使用程序计算数组元素个数吗?

答案是有的,可以使用 sizeof

我们知道数组中所有元素的类型都是相同的,那只要计算出⼀个元素所占字节的个数,数组的元素 个数就能算出来。这⾥我们选择第⼀个元素算大小就可以。

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

二维数组

1. 二维数组的概念

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

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

2.1 二维数组的创建

二维数组的基本语法如下:

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

例如:
int arr[3][5];
double data[2][8];
  • 3表示数组有3行
  •  5表示每⼀行有5个元素
  •  int 表示数组的每个元素是整型类型
  • arr是数组名,可以根据自己的需要指定名字

2.2二维数组的初始化

在创建变量或者数组的时候,给定⼀些初始值,被称为初始化。和一维数组一样,用大括号 。

不完全初始化:

//不完全初始化
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};
int arr6[][5] = {1,2,3,4,5,6,7};
int arr7[][5] = {{1,2}, {3,4}, {5,6}};

3. 二维数组的使用

3.1 二维数组的下标

其实⼆维数组访问也是使用下标的形式的,⼆维数组是有行和列的,只要锁定了行和列就能唯⼀锁定 数组中的⼀个元素。  

C语⾔规定,⼆维数组的⾏是从0开始的,列也是从0开始的,如下所示:

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


 

图中最左侧绿色的数字表示行号,第⼀行蓝色的数字表示列号,都是从0开始的,比如,我们说:第2行,第4列,快速就能定位出7。 

3.2 二维数组在内存中的储存

 

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

输出结果是:

 

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

如图所示:

 

感谢各位读者的观看。 

 

 

标签:初始化,arr,10,--,元素,int,详解,数组
From: https://blog.csdn.net/dubianjun_/article/details/140671842

相关文章

  • 【日常折腾】OPENWRT利用多网口实现路由&交换机并存且同时运行
    【前言】路由器有线网口多?交换机太贵?不想把网络布线搞得太复杂?那就试试我的AllinBoom用法吧【需求】试图在一个路由器的三个LAN口上,分割出两个不同需求的区域:上级主路由器的IP网段 192.168.1.X,本路由器的IP网段192.168.124.X一、负责当路由服务的LAN1口(开启DHCP服......
  • BI项目中ETL工程师的工作职责与技能要求
    在商业智能(BI)项目中,ETL工程师扮演着至关重要的角色,他们负责数据提取、转换和加载,确保数据仓库中的数据准确、一致和可用。一、工作职责:数据需求分析:与业务分析师和数据架构师合作,了解业务需求并确定数据提取和转换规则。数据抽取和加载:设计和实施ETL流程,从各种数据源中提......
  • 机器学习 | 回归算法原理——多项式回归
    Hi,大家好,我是半亩花海。接着上次的最速下降法(梯度下降法)继续更新《白话机器学习的数学》这本书的学习笔记,在此分享多项式回归这一回归算法原理。本章的回归算法原理基于《基于广告费预测点击量》项目,欢迎大家交流学习!目录一、多项式回归概述二、案例分析1.设置问题2.......
  • 刷题了:344.反转字符串|541. 反转字符串II|卡码网:54.替换数字
    344.反转字符串题目链接:https://leetcode.cn/problems/reverse-string/description/文章讲解:https://programmercarl.com/0344.%E5%8F%8D%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2.html视频讲解:https://www.bilibili.com/video/BV1fV4y17748/?spm_id_from=333.788&vd_sou......
  • 裸机:代码重定位实战
    任务:在SRAM中将代码从0xd0020010重定位到0xd0024000任务解释:本来代码是运行在0xd0020010的,但是因为一些原因我们又希望代码实际是在0xd0024000位置运行的。这时候就需要重定位了思路:第一点:通过链接脚本将代码链接到0xd0024000第二点:dnw下载时将bin文件下载到0xd0020010......
  • 力扣1456. 定长子串中元音的最大数目(java)
     题目描述示例思路看到“定长子串”时,我们容易联想到用滑动数组来实现这个算法。滑动数组允许我们在每次移动窗口时,只需增加新元素并减去旧元素的计数,而不必重新计算整个窗口的内容,相对于其他复杂的算法来说,实现起来更为直观和简单解题方法1.首先创建isVomel方法......
  • vmware 17.5安装 deepin23-RC2桌面社区版【超超详细图文安装教程】
    1、去官网下载安装包最新版本–深度科技社区(deepin.org)2、新建虚拟机向导,选择典型,点击下一步3、选择刚才下载好的镜像文件,点击下一步4、选择Linux,ubuntu64位5、修改虚拟机安装位置,取一个虚拟机名称6、修改磁盘大小,要大于647、自定义硬件,修改内存和处理器大......
  • 计算机专业论文 (SpringBoot/SpringCloud+Vue+MySql)
    (可辅导论文)需要源码dd毕业设计(论文)  论文题目:基于Vue和SpringCloud的旅游网站设计与实现 摘 要 本论文主要介绍了基于Vue和SpringCloud的旅游网站的设计与实现。如今,旅游业已成为社会发展中的重要组成部分,旅游平台聚集多种多样的旅行方案以及攻略,越来越多的人......
  • 16-while循环嵌套应用
    ##六.while循环嵌套应用---###6.1应用一:打印星号(正方形)---6.1.1需求```python*************************```6.1.2代码```pythonj=0whilej<5:  i=0  whilei<5:    print('*',end='')    i+=1  print('\n')......
  • 15-while循环嵌套
    五.while循环嵌套----5.1应用场景---故事梗概:有天女朋友又生气了,惩罚:说三遍:“媳妇我错了”,这个程序是不是循环即可?但是如果女朋友说:还要刷今天的碗,这个程序该怎么写?```pythonwhile条件:   print('媳妇我错了')print('刷今天的碗')```但是女朋友还生气,把这套惩罚......