一维数组详解链接:http://t.csdnimg.cn/PbzKF
前言看过一维数组,我们来看一下二维数组。
目录
目录
1. ⼆维数组的创建
1.1 ⼆维数组的概念
1.2 ⼆维数组的创建
2. ⼆维数组的初始化
2.1 不完全初始化
2.2 完全初始化
2.3 按照⾏初始化
2.4 初始化时省略⾏,但是不能省略列
3. ⼆维数组的使⽤
3.1 ⼆维数组的下标
3.2 ⼆维数组的输⼊和输出
4. ⼆维数组在内存中的存储
4. C99中的变⻓数组
1. ⼆维数组的创建
1.1 ⼆维数组的概念
数组的元素都是内置类型的,如果我们把⼀维数组做为数组的元素,这时候就是⼆维数组,⼆维数组作为数组元素的数组被称为三维数组,⼆维数组以上的数组统为多维数组。
1.2 ⼆维数组的创建
那我们如何定义⼆维数组呢?语法如下:
1
type arr_name[
常量值
1
][
常量值
2
]
;
对第一一个数组解释:
•
3表⽰数组有3⾏
•
5表⽰每⼀⾏有5个元素
•
int 表⽰数组的每个元素是整型类型
•
arr 是数组名,可以根据⾃⼰的需要指定名字
data数组意思基本⼀致。
2. ⼆维数组的初始化
在创建变量或者数组的时候,给定⼀些初始值,被称为初始化。像⼀维数组⼀样,也是使⽤⼤括号初始化的。
2.1 不完全初始化
arr1中元素内容:
arr2中的内容:
2.2 完全初始化
2.3 按照⾏初始化
2.4 初始化时省略⾏,但是不能省略列
为什么列不能省略,思考一下,数据来了需要放进二维数组,先放第一行,列数决定每行能放多少个数,若没有限制,编译器不知道什么时候才能将数据存在下一行,因此列不能省。
3. ⼆维数组的使⽤
3.1 ⼆维数组的下标
那我们怎么使⽤⼆维数组呢? 其实⼆维数组访问也是使⽤下标的形式的,⼆维数组是有⾏和列的,只要锁定了⾏和列就能唯⼀锁定数组中的⼀个元素。
C语⾔规定,⼆维数组的⾏是从0开始的,列也是从0开始的,如下所⽰:
图中最左侧绿⾊的数字表⽰⾏号,第⼀⾏蓝⾊的数字表⽰列号,都是从0开始的,
⽐如,我们说:第2⾏,第4列,快速就能定位出7。
3.2 ⼆维数组的输⼊和输出
如何访问整个⼆维数组呢?其实只要循环访问单个数组就行。
以上⼀段代码中的arr数组为例,⾏的选择范围是0~2,列的取值范围是0~4,所以我们可以借助循环实现⽣成所有的下标。完成数值的输入和输出。
4. ⼆维数组在内存中的存储
我们可以打印出数组所有元素的地址。观察规律。
从输出的结果来看,每⼀⾏内部的每个元素都是相邻的,地址之间相差4个字节,跨⾏位置处的两个元素(如:arr[0][4]和arr[1][0])之间也是差4个字节,所以⼆维数组中的每个元素都是连续存放的。如下图所⽰:
⼆维数组的每⼀⾏在内存中连续存放的,这对后面指针的学习有重要作用。
5. C99中的变⻓数组
在C99标准之前,C语⾔在创建数组的时候,数组⼤⼩的指定只能使⽤常量、常量表达式,或者如果我们初始化数据的话,可以省略数组⼤⼩。
其实这样不够灵活,有时候数组⼤了浪费空间,有时候数组⼜⼩了不够⽤的。
C99中给⼀个变⻓数组(variable-length array,简称 VLA)的新特性,允许我们可以使⽤变量指定
数组⼤⼩。
请看下⾯的代码:
1 int n = a+b;
2 int arr[n];
上⾯⽰例中,数组
arr
就是变⻓数组,因为它的⻓度取决于变量
n
的值,编译器没法事先确定,只
有运⾏时才能知道
n
是多少。
变⻓数组的根本特征,就是数组⻓度只有运⾏时才能确定,所以变⻓数组不能初始化。它的好处是程序员不必在开发时,随意为数组指定⼀个估计的⻓度,程序可以在运⾏时为数组分配精确的⻓度。有⼀个⽐较迷惑的点,变⻓数组的意思是数组的⼤⼩是可以使⽤变量来指定的,在程序运⾏的时候,根据变量的⼤⼩来指定数组的元素个数,⽽不是说数组的⼤⼩是可变的。数组的⼤⼩⼀旦确定就不能再变化了。 在VS2022上,虽然⽀持⼤部分C99的语法,没有⽀持C99中的变⻓数组,没法使用。
1 #include <stdio.h>
2 int main()
3 {
4 int n = 0;
5 scanf("%d", &n);//根据输⼊数值确定数组的⼤⼩
6 int arr[n];
7 int i = 0;
8 for (i = 0; i < n; i++)
9 {
10 scanf("%d", &arr[i]);
11 }
12 for (i = 0; i < n; i++)
13 {
14 printf("%d ", arr[i]);
15 }
16 return 0;
17 }
读者明白意思就好。
感谢观看,感谢读者指正