一、二维数组
通过学习一维数组我们不难得到二维数组,从比较好理解的方面来说其实二维数组在一维数组的每一行都加上了一列
形成了一个矩阵的形式。
定义的方式: 类型名 数组名[行的长度][列的长度];
int arr[n][m]; //n,m都为常数
在二维数组中,有一些基本的操作,就比如行列互换
举个例子:把crr[3][4]所存储的数字行列交换转换成四行三列
这里附上源代码:
#include <stdio.h>
int main()
{
int crr[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12};
int hrr[4][3];
int i,j;
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
{
hrr[j][i] = crr[i][j];
}
}
return 0;
}
二、指针和二维数组
在学习了二维数组后,产生了一个新问题,如何将二维数组传向指针,毕竟我们不能一直在主函数里写代码
在一维数组里指针指向的即为一维数组的首元素地址,而在二维数组中,直接用指针指向二维数组的话会产生二意,计算机是不会允许产生二意的。
其实,我们可以抽象的将二维数组的一行当做一个元素,使其指针又成了指向首元素地址,这种指针每一个都存储的是数组(即就是二维数组的行),存储数组的指针我们便将其叫做数组指针。
那相应的就会有指针数组,即就是存储指针的数组
可以参考下图: