碰到一道非常懵逼的题:
若有以下定义和赋值语句,则与&s[i][j]等价的是()【*(p+i)+j】
int s[2][3] = {0}, (*p)[3], i, j;
p = s;
i = j = 1;
那么这道题怎么看呢,首先有一个整形的二维数组,然后看第一个知识点int (*p)[3]
定义 int (*p)[n];
()和[]优先级,参考 http://www.jb51.net/article/37282.htm
首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,
n也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
如要将二维数组赋给一指针,应这样赋值:
int a[3][4];
int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。
p=a; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
p++; //该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]
所以数组指针也称指向一维数组的指针,亦称行指针。
参考至:http://www.cnblogs.com/mq0036/p/3382732.html 超级好的文章
若有以下定义和赋值语句,则与&s[i][j]等价的是()【*(p+i)+j】
int s[2][3] = {0}, (*p)[3], i, j;
p = s;
i = j = 1;
那么这道题怎么看呢,首先有一个整形的二维数组,然后看第一个知识点int (*p)[3]
定义 int (*p)[n];
()和[]优先级,参考 http://www.jb51.net/article/37282.htm
首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,
n也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
如要将二维数组赋给一指针,应这样赋值:
int a[3][4];
int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。
p=a; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
p++; //该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]
所以数组指针也称指向一维数组的指针,亦称行指针。
参考至:http://www.cnblogs.com/mq0036/p/3382732.html 超级好的文章