<谭> 7.2.3
C语言中,二维数组中元素排列的顺序是:按行存放,即在内存中先顺序放第一行的元素,再存放第二行的元素。
二维数组的初始化:
(1) 分行给二维数组赋初值。如
int a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
这种赋初值方法比较直观,把第1个花括弧内的数据给第1行的元素,第2个花括弧内的数据赋给第2行的元素……即按行赋初值。
(2) 可以将所有数据写在一个花括弧内,按数组排列的顺序对各元素赋初值。如:
int a[3][4]={1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11,12};
效果与前相同。但以第1种方法为好,一行对一行,界限清楚。用第2种方法如果数据多,写成一大片,容易遗漏,也不易检查。
(3) 可以对部分元素赋初值。
int a[3][4]={{1},{5},{9}};
它的作用是只对各行第1列的元素赋初值,其余元素值自动为0。赋初值后数组各元素为
1 0 0 0
5 0 0 0
9 0 0 0
也可以对各行中的某一元素赋初值:
int a[3][4]={{1},{0,6},{0,0,11}};
初始化后的数组元素如下:
1 0 0 0
0 6 0 0
0 0 11 0
这种方法对非0元素少时比较方便,不必将所有的0都写出来,只需输入少量数据。也可以只对某几行元素赋初值:
int a[3][4]={{1},{5,6}};
数组元素为
1 0 0 0
5 6 0 0
0 0 0 0
第3行不赋初值。也可以对第2行不赋初值:
int a[3][4]={{1},{},{9}};
(4) 如果对全部元素都赋初值(即提供全部初始数据),则定义数组时对第一维的长度可以不指定,但第二维的长度不能省。如:
int a[3][4]={1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12};
与下面的定义等价:
int a[][4]={1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12};
系统会根据数据总个数分配存储空间,一共12个数据,每行4列,当然可确定为3行。
在定义时也可以只对部分元素赋初值而省略第一维的长度,但应分行赋初值。如:int a[][4]={{0,0,3},{},{0,10}};
这样的写法,能通知编译系统;数组共有3行。数组各元素为
0 0 3 0
0 0 0 0
0 10 0 0
从本节的介绍中可以看到:c语言在定义数组和表示数组元素时采用a[][]这种两个方括弧的方式,对数组初始化时十分有用,它使概念清楚,使用方便,不易出错。
练一个: 将一个二维数组行和列元素互换,存到另一个二维数组中。例如:
┌1 2 3┐ ┌1 4┐
a =│ │ b= │2 5│
└4 5 6┘ └3 6┘
#include <stdio.h>
int main()
{
int a[2][3] = {{1, 2, 3}, {4, 5, 6}};
int b[3][2];
int i, j;
printf("array a:\n\n");
for (i = 0; i <= 1; i++)
{
for (j = 0; j <= 2; j++)
{
printf("%5d", a[i][j]);
b[j][i] = a[i][j];
}
printf("\n");
}
printf("\narray:b\n\n");
for (i = 0; i <= 2; i++)
{
for (j = 0; j <= 1; j++)
printf("%5d", b[i][j]);
printf("\n");
}
return 0;
}
运行结果:
=========================
array a:
1 2 3
4 5 6
array:b
1 4
2 5
3 6
=========================
######################################拾遗########################################
若要初始化一个二维数组所有元素为0,可采用此法: a[5][5]={{0}};
注: 未经初始化的数组元素默认不为0
验证如下:
#include <stdio.h>
int main()
{
int a[5][5]; /* 数组所有元素初始化为0 的方法! */
int i, j;
for (i = 0; i < 5; i++)
{
for(j = 0; j < 5; j++)
printf("%12d", a[i][j]);
printf("\n");
}
return 0;
}
运行结果(TC):
===================================================================
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
-58 1168 80 0 0
-48 1369 0 64 3129
===================================================================
运行结果(VC):
===================================================================
-858993460 -858993460 -858993460 -858993460 -858993460
-858993460 -858993460 -858993460 -858993460 -858993460
-858993460 -858993460 -858993460 -858993460 -858993460
-858993460 -858993460 -858993460 -858993460 -858993460
-858993460 -858993460 -858993460 -858993460 -858993460
===================================================================
#include <stdio.h>
int main()
{
int a[5][5]={{0}}; /* 数组所有元素初始化为0 的方法! */
int i, j;
for (i = 0; i < 5; i++)
{
for(j = 0; j < 5; j++)
printf("%2d", a[i][j]);
printf("\n");
}
return 0;
}
运行结果:
======================
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
======================
评论