3 指向二维数组指针的定义及数组元素的引用
在使用指针指向二维数组时首先要了解多维数组元素的地址表示方式,假设有二维数组a[3][3],那么在逻辑上可以把这个二维数组看作是一个3行3列的表格,也可以看成是一个有3个元素的一维数组,该数组的每个元素也是一个一维数组,序号为0的行的首地址可以用a[0]、&a[0]或a表示,序号为1的行的首地址可表示为a[1]、&a[1]或a+1,如图1所示。根据一维数组指针的定义,a[0]的值可以又表示成为*a,a[1]可以表示为*(a+1),a[i]即为*(a+i)。序号为0的行的首地址也就是元素a[0][0]的地址,即&a[0][0],它后面几个元素的地址可以表示为a[0]+1,a[0]+2 ,若用指针法表示为*(a+0)、*(a+0)+1和*(a+0)+2,以此类推,第i行第j列元素的地址&a[i][j]可以表示成为a[i]+j,指针法表示为*(a+i)+j,也就是说&a[i][j]、a[i]+j、*(a+i)+j是等价的。这样,对于一个二维数组来说,元素a[i][j]可用指针法表示为*(a[i]+j)或*(*(a+i)+j)。
void main( )
{ int a[3][4]={1,3,5,7,9,11,13,15,17,19,21,23};
int (*p)[4]=a,i,j,k=0;
for(i=0;i<3;i++)
for(j=0;j<2;j++)
k=k+*(*(p+i)+j);
printf(“k=%d\n”,k);}
程序分析:此实例中,指针p指向二维数组a的首地址,然后执行循环,首先i=0,j=0,累加*(*(p+0)+0),即a[0][0],接着i=0,j=1,累加*(*(p+0)+1),即a[0][1],然后j=2时跳出内循环,以此类推,执行下一次外循环i=1时,累加a[1][0]和a[1][1],执行外循环i=2时累加a[2][0]和a[2][1]……最后i=3时跳出整个循环,由此看出,语句在这里其实就是累加二维数组第一列和第二列的元素。最后结果为1+3+9+11+17+19=60,输出“k=60”。
总之,指针和数组结合起来使用非常灵活,同一地址有多种表示方法,而指针根据地址表示的不同可定义成指向数组元素的指针和指向某行数据的指针,初学者很难理解,大家一定要从C语言的数组和指针的概念出发,仔细琢磨,反复思考,多比较,多应用, 如果能很好地应用指针访问数组,对C语言后面的知识学习有很大帮助,如C语言的结构体、共用体、链表等,都是跟指针和数组相关的,正确灵活地运用指针,可以使程序更加简洁、紧凑、高效。
参考文献
[1] 谭浩强.C程序设计[M].4版.北京:清华大学出版社,2010.
[2] 未来教育.全国计算机等级考试模拟考场二级C[M].成都:电子科技大学出版社,2015.
[3] 教育部考试中心.全国计算机等级考试二级教程-C语言程序设计[M].北京:高等教育出版社,2002.