多维数组

简介: 多维数组

C 语言支持多维数组。多维数组声明的一般形式如下:

type name[size1][size2]...[sizeN];


例如,下面的声明创建了一个三维 5 . 10 . 4 整型数组:

int threedim[5][10][4];


二维数组

多维数组最简单的形式是二维数组。一个二维数组,在本质上,是一个一维数组的列表。声明一个 xy 列的二维整型数组,形式如下:

type arrayName [ x ][ y ];


其中, type 可以是任意有效的 C 数据类型, arrayName 是一个有效的 C 标识符。一个二维数组可以被认为是一个带有 x 行和 y 列的表格。下面是一个二维数组,包含 3 行和 4 列:

int x[3][4];


二维数组.jpg


因此,数组中的每个元素是使用形式为 a[i,j] 的元素名称来标识的,其中 a 是数组名称, ij 是唯一标识 a 中每个元素的下标。


初始化二维数组

多维数组可以通过在括号内为每行指定值来进行初始化。下面是一个带有 34 列的数组。

int a[3][4] = {  
 {0, 1, 2, 3} ,   /*  初始化索引号为 0 的行 */
 {4, 5, 6, 7} ,   /*  初始化索引号为 1 的行 */
 {8, 9, 10, 11}   /*  初始化索引号为 2 的行 */
};


内部嵌套的括号是可选的,下面的初始化与上面是等同的:

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


访问二维数组元素

二维数组中的元素是通过使用下标(即数组的行索引和列索引)来访问的。例如:

int val = a[2][3];


上面的语句将获取数组中第 3 行第 4 个元素。您可以通过上面的示意图来进行验证。让我们来看看下面的程序,我们将使用嵌套循环来处理二维数组:

#include <stdio.h>
int main ()
{
   /* 一个带有 5 行 2 列的数组 */
   int a[5][2] = { {0,0}, {1,2}, {2,4}, {3,6},{4,8}};
   int i, j;
   /* 输出数组中每个元素的值 */
   for ( i = 0; i < 5; i++ )
   {
      for ( j = 0; j < 2; j++ )
      {
         printf("a[%d][%d] = %d\n", i,j, a[i][j] );
      }
   }
   return 0;
}


当上面的代码被编译和执行时,它会产生下列结果:

a[0][0] = 0
a[0][1] = 0
a[1][0] = 1
a[1][1] = 2
a[2][0] = 2
a[2][1] = 4
a[3][0] = 3
a[3][1] = 6
a[4][0] = 4
a[4][1] = 8


如上所述,可以创建任意维度的数组,但是一般情况下,我们创建的数组是一维数组和二维数组。

目录
相关文章
|
8月前
|
存储 算法 搜索推荐
15一维数组
15一维数组
66 0
|
8月前
|
存储
多维数组求和函数
多维数组求和函数
|
4月前
|
API Python
Numpy 数组的一些集合操作
Numpy 数组的一些集合操作
48 0
|
8月前
|
存储 编译器 C语言
认识一维数组和使用
**数组概念与特性:**数组是一组相同类型元素的集合,包含至少一个元素。数组可分为一维和多维(如二维数组)。在创建时需指定大小和元素类型,如`int arr[5]`表示一个包含5个整数的数组。数组元素通过下标访问,下标从0开始。数组在内存中连续存放,可以通过`sizeof`计算数组占用的字节数以间接获取元素个数。
58 1
|
8月前
|
编译器 C语言
多维数组名作函数参数
多维数组名作函数参数
48 0
|
8月前
|
C语言
指针和多维数组
指针和多维数组
|
8月前
数组操作吧
数组操作吧
|
存储 C语言
一维数组剖析
一维数组剖析
52 0
|
存储 程序员 C++
C / C++ 中的多维数组
在 C/C++ 中,我们可以用简单的话将多维数组定义为数组数组。多维数组中的数据以表格形式(按行主顺序)存储。
226 0
|
存储 算法 编译器