1. 二维数组的定义
类型名 数组名常量表达式常量表达式
如:int a34;
数组a中含有的元素有:a00, a01, a02, a03,a10, a11, a12, a13, a20, a21, a22, a23。
2. 二维数组的存储结构
二维数组中的下标变量在内存中的实际存储结构是线性的,不是二维的。想象成有行有列的二维表格形式,只是它们之间的逻辑关系。
以int a34为例,各个下标变量排列的先后顺序是:先是a0的四个变量,再是a1的四个变量,最后是a2的四个变量。
3.二维数组中下标变量的表示方法
下标法:如a12,表示的是a1这个一维数组中的第二个元素。
指针法:如*(*(a+1)+2)。a12相当于是(a1)2,由于x2与*(x+2)等价,所以(a1)2与*(a1+2)等价,这时候再把a1换成*(a+1),就可以得到*(*(a+1)+2)。
混合法:如*(a1+2),*(a+1)2。
4. 二维数组的引用
(1)二维数组中的下标变量在表示时,要么有两个*,要么有两对\[\],有么有一个*和一个\[\]。*和\[\]都用来降维,当维数降为0时,就是变量。
(2)每次只能使用数组中的一个下标变量,若要操作多个下标变量,需要分多次进行操作。
cpp
int a[2][3],i,j;
for(i=0;i<=1;i++)
for(j=0;j<=2;j++)
a[i][j]=0;
5. 二维数组的初始化
(1)给所有下标变量赋初值
cpp
int a[2][3]={1,2,3,4,5,6};
(2)可以给每行数据再加一对大括号
cpp
int a[2][3]={{1,2,3},{4,5,6}};
(3)可以省略第一个 中的表达式,省略时,编译器自动填上。
cpp
int a[][3]={1,2,3,4}; //相当于int a[2][3];
int a[][3]={{1,2},{3},{4}}; //相当于int a[3][3];
(4)可以只对部分下标变量赋初值
cpp
int a[2][3]={1,2,3}; //下标变量的值依次为1,2,3,0,0,0
int a[][3]={{1,2},{1}}; //下标变量的值依次为1,2,0,1,0,0