二维数组
前面介绍了一维数组,接下来介绍如何定义和使用二维数组。
二维数组定义的一般形式如下:
类型说明符 数组名[常量表达式1][常量表达式2]
与一维数组的定义唯一的不同是多了一个常量表达式2,其中,常量表达式1为第一维的长度,常量表达式2为第二维的长度。通常在处理二维数组的时候,为了便于理解,都将数组视为一个矩阵,常量表达式1表示矩阵的行数,而常量表达式2表示矩阵的列数。与一维数组一样,在定义二维数组时,常量表达式同样不能为变量。下面先通过一段代码来看二维数组的定义。
#include<stdio.h>
#define M 4
#define N 3
intmain() {
intarr[M][N];
for (inti=0; i<M; i++)
{
for (intj=0; j<N; j++)
{
printf("&arr[%d][%d]=%d\t", i, j, &arr[i][j]);
}
printf("\n");
}
return0;
}
运行结果:将二维数组arr视为一个矩阵,下图显示了数组中每个元素在矩阵中的存放位置。数组中各个元素在矩阵中对应的位置由二维数组的两个下标决定。我们可以将定义的二维数组int arr4视为由arr[4]和int [3] 两部分构成,将arr[4]视为一个整型一维数组,其中含有4个元素arr[0]、arr[1]、arr[2]、arr[3],每个元素都是int[3]类型的,也就是说,每个元素又是一个一维数组,每个一维数组含有3个元素,如arr[0]含有arr0、arr0、arr0三个元素。
知道了二维数组的这种特殊结构之后,接下来通过下图来了解二维数组在内存中的存储结构。通过上述二维数组在内存中的存储结构图可以发现,二维数组中的所有元素都存储在一片连续的内存单元中,所占用的内存大小为元素类型所占用的内存大小乘以第一维及第二维的长度。如果以矩阵的方式来分析二维数组的存储方式,那么先从矩阵第一行从左往右依次存储完所有元素,然后按照同样的方法存储第二行的所有元素,直到存储完所有数组元素为止。
接下来再看一个二维数组的示例:
任意输入一个3行3列的二维数组,求对角元素之和
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
intmain() {
intarr[3][3];
inti, j, sum=0;
printf("please input:\n");
for (i=0; i<3; i++)
{
for (j=0; j<3; j++)
{
scanf("%d", &arr[i][j]);
}
}
for (i=0; i<3; i++)
{
for ( j=0; j<3; j++)
{
if (i==j)
{
sum+=arr[i][j];
}
}
}
printf("the result is: %d\n", sum);
return0;
}
运行结果如下:关于二维数组就介绍到这,后面继续更新。。。