二维数组(数组指针的存储形式)

首先,原理为一维数组的数组名表示数组首元素的地址

看以下代码:

#include<stdio.h>

//void Show(int **brr)//error,如果传的是二维数组,则该方法是错误的,说明二维数组名并不是二级指针
//void Show(int brr[3][4])//这样的话对二维数组过于限制,将行列都给出,不便于代码的重用,不好
void Show(int (*brr)[4])//数组指针,用括号将*也括入,*brr==arr,将二维数组当作一维数组看,所以把*brr括入。右边带上列的数量。
{
	for(int i=0;i<3;i++)
	{
		for(int j=0;j<4;j++)
		{
			printf("%d",brr[i][j]);
		}
		printf("\n");
	}
}

//二维数组初始化的不同方式
int main()
{
	int a = 10;
	int arr[4] = {1,2,3,4};
	int brr[3][4];
	int crr[3][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
	int drr[3][4] = {1,2,3,4,5,6,7,8,9};//行优先
	int err[][4] = {1,2,3,4,5,6};
	brr[2][1] = 1;
	Show(crr);//
	return 0;
}
其中,Show()函数中的数组指针引用方式说明brr指针是一个指向4个单元的一维数组的指针,类型为int。
阅读更多

没有更多推荐了,返回首页