1.二维数组
定义及初始化:
int a[2][3]={{1,2,3},
{4,5,6}};
上面定义并初始化了二维数组,类似于2行3列的行列式,可以认为由两个数组组成,a[0]和a[1]两个数组。
2.二维数组指针类型
//数组元素的地址
int *p0=&a[1][1];
//一维数组的地址
int (*p1)[3]=&a[1];
//二维数组的类型地址
int (*p2)[2][3]=&a;
分解定义:先定义一个指针*p
,再指向二维数组类型a[2][3]
,*
的优先级别比较高,需要加(),所以int (*p)[2][3];
不加()的话为指针数组,数组元素是指针类型。
3.使用
注:数组名字==数组首元素的首地址,即a==&a[0],a[0]==&a[0][0],a[1]==&a[1][0];
二维数组指针遍历二维数组,p指向变量的地址,*p
就是变量本身。
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
printf("%d ", (*p2)[i][j]);
//等价于printf("%d ", a[i][j]);
}
}
4.利用指针遍历二维数组:
a.数组元素的指针;
int a[2][3] = {{1, 2, 3},
{4, 5, 6}};
int *p = &a[0][0];
int *p1 = &a[1][1];
for (int i = 0; i < 6; i++)
{
//全部打印数组的元素
printf("%d ", *(p + i));
}
printf("\n");
//也可以通过另一种方式打印全部数组元素
printf("%d %d %d %d %d %d", (*p1 - 4), (*p1 - 3), (*p1 - 2), (*p1 - 1), *p1, *(p1 + 1));
运行结果:
利用这种方式可以使用一个for循环就打印出数组元素,如果直接通过a[i][j]
方式打印那需要两个for循环。使用这种方式可以减少时间复杂度减少,提高执行效率。
当然,也可以通过定义一个指向除了数组首元素的之外的任意元素的地址,再进行加减运算也可以访问数组元素。
b.一维数组的指针
int a[2][3] = {{1, 2, 3},
{4, 5, 6}};
int(*p2)[3] = &a[0];
/*p2==a[0]==a;
*p2==a;
a[0][0]==(*p2)[0];
*(p2+1)==a[1];
*/
printf("%d %d %d\n", (*p2)[1], *(p2 + 1)[0], p2[1][0]);
运行结果:
这里,p2和a的用法是一样的。
c.二维数组的指针。
int a[2][3] = {{1, 2, 3},
{4, 5, 6}};
int(*p3)[2][3] = &a;
//*p3==a;
printf("%d %d\n", a[1][2], (*p3)[1][2]);
运行结果: