一、指向一维数组的指针变量
设一维数组为a[n]
定义方法:*P(*指针变量名)
赋值:p=a,或者p=&a[0];(p指向的是一维数组的首地址)
1、p , a , &a[0]均指向同一单元a[0],它们是数组a的首地址,也是0号元素a[0]的首地址。
p+1,a+1,&a[1]均指向1号元素a[1]。类推可知a+i,a+i,&a[i]。
例:
#include
int main()
{
int a[5],i,*p;
p=a;
for(i=0;i<5;i++)
*p++=i;
p=a;
for(i=0;i<5;i++)
printf(a[%d]=%d\n,i,*p++);
}
int main()
{
int a[5],i,*p;
p=a;
for(i=0;i<5;i++)
*p++=i;
p=a;
for(i=0;i<5;i++)
printf(a[%d]=%d\n,i,*p++);
}
二、指向二维数组的指针变量
设二维数组为a[m][n]
定义方法:(*P)[n]((*指针变量名)[长度])
“长度”表示二维数组分解为多个一维数组时,一维数组的长度,也就是二维数组的列数。
1、多维数组有关概念
以二维数组为例,
二维数组实质是一个以一维数组为元素的数组,那么二维数组名代表的是整个一维数组的地址(即二维数组第一个元素的地址)
那么,a[0],a[1],a[2]表示的是二维数组中一维数组的首地址,它也是数组名,而不是一个元素
2、多维数组地址的表示方法
设有整型二维数组a[3][4],设数组a的首地址为1000
C语言允许把一个二维数组分解为多个一维数组来处理(以一维数组为元素)。
因此数组a可分解为三个一维数组,即a[0],a[1],a[2]。每一个一维数组又含有四个元素,例如a[0]数组,含有a[0][0],a[0][1],a[0][2],a[0][3]四个元素。
那么,数组及数组元素的地址表示方法和解释如下:
—1———————————————————————————————————————————————————————————————————————
a是二维数组名,也是二维数组0行的首地址,即整个一维数组的地址,等于1000。那么思考:a+1表示什么
a[0]是第一个一维数组的数组名,也是一维数组的首地址,因此也为1000。 再思考:a[0]+1表示什么
*(a+0)或*a是与a[0]等效的,它表示一维数组a[0]的0号元素的首地址,也为1000。(*a不是&a[0])
&a[0][0]是二维数组a的0行0列元素首地址,同样是1000。
因此,a,a[0],*(a+0),*a,&a[0][0]的值是相等的,但是意义不同。
—2————————————————————————————————————————————————————————————————————————
同理,a+1是二维数组1行的首地址,等于1008。
a[1]是第二个一维数组的数组名和首地址,因此也为1008。
&a[1][0]是二维数组a的1行0列元素地址,也是1008。
因此a+1,a[1],*(a+1),&a[1][0]是值是相同的。
—3—————————————————————————————————————————————————————————————————————————
由此可得出:a+i,a[i],*(a+i),&a[i][0]是的值是相同的。
拓展:
&a[i][和a[i]是等同的。因为在二维数组中不能把&a[i]理解为元素a[i]的地址,不存在元素a[i]。C语言规定,它是一种地址计算方法,表示数组a第i行首地址。
由此,我们得出:a[i],&a[i],*(a+i)和a+i的值也都是相同的。
另外,a[0]也可以看成是a[0]+0是一维数组a[0]的0号元素的首地址,而a[0]+1则是a[0]的1号元素首地址,由此可得出a[i]+j则是一维数组a[i]的j号元素首地址,它等于&a[i][j]。
由a[i]=*(a+i)得a[i]+j=*(a+i)+j,由于*(a+i)+j是二维数组a的i行j列元素的首地址。该元素的值等于*(*(a+i)+j)。