可以
C中没有真正意义上的二维数组,是通过一维数组扩展实现的,数组的每一项再存放指向一维数组的手指针。例如:
int a[4][5];
int (*p)[5]
p=a
这里的p即为a[4]的首地址,也就是说p指向了4*5的数组,指针里的5表示第二维度数组的长度即第一行数据的个数,如果b中int (*p)[<5],则会不够存储A中数组第二维度的长度,就会出错。
最终存储的二维数组将会全部展开成一维数组,所以你直接申明int *p 指向该二维数组,那么这里的p即为a[0][0],p+6即为a[1][0]
当然可以。因为二维数组在内存中也是按照一维方式存放的(内存单元是一维的)。下面有个参考程序你可以试试。
#include
void main()
{
int a[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
int *p=a;
printf("%d\n",*p);//结果输出1,将*p改写成*(p+1)则输出2,改写成*(p+7)则输出8,可见*p可以指向二维数组中的任何一个元素。
}
可以,二维数组其实还是一维数组,没有本质的区别。
比如
int a[3[4];
我们可以
int *p = &a[0][0];
这样可以用p直接访问a[][];
而且2楼的说法欠妥,二维数组不是指向指针的指针,他只有一个指针,指向某段内存,而且此段内存内存的是数据,而非指针。
二维数组是指针的指针
它本身是个指针,指向一个指针数组,该指针数组的每个元素都是个指针,指向该行(或者列)的第一个元素
给你一个参考例子,它们的关系可以从例子中看到。
#include
int main()
{
int a[3][4], i, j;
int *p, (*p1)[4];
for (i = 0; i < 3; ++i)
{
p = a[i];
for (j = 0; j < 4; ++j)
scanf("%d", p++);
}
p1 = a;
for (i = 0; i < 3; ++i)
{
for (j = 0; j < 4; ++j)
printf("%d ", p1[i][j]);
}
putchar('\n');
return 0;
}