首页 百科知识 二维数组怎么转为多维

二维数组怎么转为多维

时间:2022-10-03 百科知识 版权反馈
【摘要】:本小节只介绍二维数组,多维数组可由二维数组类推而得到。二维数组在概念上是二维的,即其下标在两个方向上变化,下标变量在数组中的位置也处于一个平面之中,而不是像一维数组只是一个向量。在一维存储器中存放二维数组有两种方式:一种是按行排列,即放完一行之后顺次放入第二行;另一种是按列排列,即放完一列之后再顺次放入第二列。在C语言中,二维数组是按行排列的。

前面介绍的数组只有一个下标,称为一维数组,其数组元素称为单下标变量。在实际问题中,有很多量是二维的或多维的,因此C语言允许构造多维数组。多维数组元素有多个下标,以标识它在数组中的位置,所以也称为多下标变量。本小节只介绍二维数组,多维数组可由二维数组类推而得到。

二维数组定义的一般形式是:

类型说明符数组名[常量表达式1][常量表达式2];

其中常量表达式1表示第一维下标的长度,常量表达式2表示第二维下标的长度。

例如:

inta[3][4];

说明了一个三行四列的数组,数组名为a,其下标变量的类型为整型。该数组的下标变量共有3×4个,即

a[0][0],a[0][1],a[0][2],a[0][3]

a[1][0],a[1][1],a[1][2],a[1][3]

a[2][0],a[2][1],a[2][2],a[2][3]

二维数组在概念上是二维的,即其下标在两个方向上变化,下标变量在数组中的位置也处于一个平面之中,而不是像一维数组只是一个向量。但是,实际的硬件存储器却是连续编址的,也就是说,存储器单元是按一维线性排列的。在一维存储器中存放二维数组有两种方式:一种是按行排列,即放完一行之后顺次放入第二行;另一种是按列排列,即放完一列之后再顺次放入第二列。在C语言中,二维数组是按行排列的。即先存放a[0]行,再存放a[1]行,最后存放a[2]行。每行中有四个元素,也是依次存放的。由于数组a说明为int类型,该类型占两个字节的内存空间,所以每个元素均占有两个字节。

免责声明:以上内容源自网络,版权归原作者所有,如有侵犯您的原创版权请告知,我们将尽快删除相关内容。

我要反馈