二维数组的基本概念在这里不在多提,即他的定义和特点。先从二维数组的输出来说吧。
二维数组的输出
int main()
{
int arr[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
for(int i=0;i<3;i++)
{
for(int j=0;j<4;j++)
{
printf("%d",arr[i][j]);
}
printf("\n");
}
}
二维数组的逆置
即本来的 行换成列,列换成行,这个很简单我们看来看一下代码和结果:
int main()
{
int arr[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
for(int i=0;i<3;i++)
{
for(int j=0;j<4;j++)
{
printf("%d",arr[i][j]);
}
printf("\n");
}
printf("——————\n");
for(int i=0;i<4;i++)
{
for(int j=0;j<3;j++)
{
printf("%d",arr[j][i]);
}
printf("\n");
}
}
很显然,操作结果是成功的。
我们想要的逆置,在本来的矩阵里,不就是需要达到arr[0][1]变成[1][0],以此类推,如图所示
来看图里的代码,我们看一下操作,其实不就是三行四列换成了四列三行,输出的arr[][]中间的i j调换位置,上面的循环中i和j分别<的数据也要换成相对应的。
二维数组的操作单独成函数
在一维数组的时候我们知道一个套路:传指针和传长度
我们来看看一维数组的操作:
void Show1(int *brr,int len)
{
for(int i=0;i<len;i++)
{
printf("%d",brr[i]);
printf(" ");
}
printf("\n");
}
int main()
{
int brr[]={1,2,3,4,5,6,7};
Show1(brr,7);
return 0;
}
我们以此类推,那么二维数组是不是就应该是二级指针?是吗?很显然是错的!不是!
在这里就有一个新词数组指针,它是怎么一回事呢?既然一维数组的时候我们传指针,传长度。二级指针根本在二维数组这里行不通,那么我们想可不可以把二维数组模拟成一维数组呢?
图左边是一维数组,右边我们模拟二维数组中的一行为一个一维数组中元素,那么依旧是就是三个元素,红色蓝色绿色代编三个元素。如何来表示这一行作为一个元素呢?那就是需要一个指向数组的指针简称数组指针。int(*p)[4]: 星号和P定义了一个指针,int [4],int指这个数组里面有4个int型的变量。也就是p指向一个包含4个int类型数据的数组。 {中括号的运算优先级高于星号,给星号P加了括号,就先运算小括号了}
在一维数组里,数组名就是是首元素的地址(比如图中的arr即该一维数组中第一个元素的地址)它的类型是 int *p 同理!图中的brr是我们定义的二维数组名称,他的名称也是首元素的地址啊,但是这里的首地址并不是brr[0][0]而是第一横行为一个整体的元素。也就是int(*p)[4]。
那我们来尝试用这个定义来将二维数组的操作单独成一个函数。
void Show2(int (*arr)[4],int row,int col)
{
for(int i=0;i<row;i++)
{
for(int j=0;j<col;j++)
{
printf("%d",arr[i][j]);
}
printf("\n");
}
}
int main()
{
int arr[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
Show2(arr,3,4);
return 0;
}
没问题!成功运行!
还有一种方法在参数定义这里有所不同
void Show3(int arr[3][4],int row,int col)
{
for(int i=0;i<row;i++)
{
for(int j=0;j<col;j++)
{
printf("%d",arr[i][j]);
}
printf("\n");
}
}
int main()
{
int arr[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
Show3(arr,3,4);
return 0;
}
本次分享到此结束,后面有新的感悟,学习内容。继续更新!