2个回答
展开全部
int (*p)[4]=a ; 定义一个行指针,并指向二维数组的第0行(a 在这里表示二维数组的首地址,即第0行的首地址,这和一维数组有些区别) int *q=a[0]; 或者 int *q = &a[0][0]; 这两个效果一样, 都创建了一个简单的整型指针,并指向二维数组第一个元素的首地址,这样的话 指针可以在数组中逐个访问数组元素.(在二维数组 a[3][4]里 a[0] 表示第0行第0列元素的地址,依次类推 a[i]+j 表示第 i 行第 j 列元素的地址) (*p)[i+i/2]=*q+1; 这段代码只执行一次, (*p)[i+i/2] 表示第0行第 0 列的元素((*p)与a[0]是等价的) *q表示 第0 行第0列元素的值1,所以这句话的意思是把 二维数组的第一个元素加 1,变成2 ,p++,++q这句话执行两次,p指向第2行,q指向第2列,接下来就是显示 a[0][0] a[1][1] a[2][2] ( a[0][0]已经变为2),*((int *)p) 与 a[2][0]等价 *q 与 a[0][2]等价
个人见解 ,仅供参考!
个人见解 ,仅供参考!
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询