指向数组元素的指针

我们定义一个整型数组和一个指向整型的指针变量:

inta[10], *p;

和前面介绍过的方法相同,可以使整型指针p指向数组中任何一个元素,假定给出赋值运算

p=&a[0];

此时,p指向数组中的第0号元素,即a[0],指针变量p中包含了数组元素a[0]的地址,由于数组元素在内存中是连续存放的,因此,我们就可以通过指针变量p及其有关运算间接访问数组中的任何一个元素。

TurboC中,数组名是数组的第0号元素的地址,因此下面两个语句是等价的

p=&a[0];

p=a;

根据地址运算规则,a+1为a[1]的地址,a+i就为a[i]的地址。

下面我们用指针给出数组元素的地址和内容的几种表示形式。

(1).p+i和a+i均表示a[i]的地址,或者讲,它们均指向数组第i号元素,即指向a[i]。

(2).*(p+i)和*(a+i)都表示p+i和a+i所指对象的内容,即为a[i]。

(3).指向数组元素的指针,也可以表示成数组的形式,也就是说,它允许指针变量带下标,如p[i]与*(p+i)等价。

假若:p=a+5;

则p[2]就相当于*(p+2),由于p指向a[5],所以p[2]就相当于a[7]。而p[-3]就相当于*(p-3),它表示a[2]。

只要把[]当成一个运算符就好了

 

2.2.指向二维数组的指针

2.2.1.二维数组元素的地址

为了说明问题,我们定义以下二维数组:

inta[3][4]={{0,1,2,3},{4,5,6,7},{8,9,10,11}};

a为二维数组名,此数组有3行4列,共12个元素。但也可这样来理解,数组a由三个元素组成:a[0],a[1],a[2]。而它匀中每个元素又是一个一维数组,且都含有4个元素(相当于4列),例如,a[0]所代表的一维数组所包含的4个元素为a[0][0],a[0][1],a[0][2],a[0][3]。如图5.所示:

    ┏━━━━┓   ┏━┳━┳━┳━┓ 

a─→┃a[0]┃─→  ┃0 ┃1 ┃2 ┃3 ┃ 

    ┣━━━━┫   ┣━╋━╋━╋━┫ 

    ┃ a[1] ┃─→┃4 ┃5 ┃6 ┃7┃ 

    ┣━━━━┫    ┣━╋━╋━╋━┫ 

     ┃ a[2] ┃─→┃8 ┃9┃10┃11┃ 

    ┗━━━━┛    ┗━┻━┻━┻━┛ 

图5.

但从二维数组的角度来看,a代表二维数组的首地址,当然也可看成是二维数组第0行的首地址。a+1就代表第1行的首地址,a+2就代表第2行的首地址。如果此二维数组的首地址为1000,由于第0行有4个整型元素,所以a+1为1008,a+2也就为1016。如图6.所示

a[3][4]

a            ┏━┳━┳━┳━┓ 

(1000)─→┃0┃1 ┃2 ┃3 ┃

a+1         ┣━╋━╋━╋━┫ 

(1008)─→┃4┃5 ┃6 ┃7 ┃

a+2         ┣━╋━╋━╋━┫ 

(1016)─→┃8┃9 ┃10┃11┃

              ┗━┻━┻━┻━┛ 

图6.

既然我们把a[0],a[1],a[2]看成是一维数组名,可以认为它们分别代表它们所对应的数组的首地址,也就是讲,a[0]代表第0行中第0列元素的地址,即&a[0][0],a[1]是第1行中第0列元素的地址,即&a[1][0],根据地址运算规则,a[0]+1即代表第0行第1列元素的地址,即&a[0][1],一般而言,a[i]+j即代表第i行第j列元素的地址,即&a[i][j]。

另外,在二维数组中,我们还可用指针的形式来表示各元素的地址。如前所述,a[0]与*(a+0)等价,a[1]与*(a+1)等价,因此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和*a,你可发现它们的值是相同的,这是为什么呢?我们可这样来理解:首先,为了说明问题,我们把二维数组人为地看成由三个数组元素a[0],a[1],a[2]组成,将a[0],a[1],a[2]看成是数组名它们又分别是由4个元素组成的一维数组。因此,a表示数组第0行的地址,而*a即为a[0],它是数组名,当然还是地址,它就是数组第0行第0列元素的地址。

 

 

 

 

2.2.2指向一个由n个元素所组成的数组指针

在TurboC中, 可定义如下的指针变量:

int(*p)[3];

指针p为指向一个由3个元素所组成的整型数组指针。在定义中,圆括号是不能少的,否则它是指针数组,这将在后面介绍。这种数组的指针不同于前面介绍的整型指针,当整型指针指向一个整型数组的元素时,进行指针(地址)加1运算,表示指向数组的下一个元素,此时地址值增加了2(因为放大因子为2),而如上所定义的指向一个由3个元素组成的数组指针,进行地址加1运算时,其地址值增加

了6(放大因子为2x3=6),这种数组指针在Turbo C中用得较少,但在处理二维数组时,还是很方便的。例如:

int a[3][4], (*p)[4];

p=a;

开始时p指向二维数组第0行,当进行p+1运算时,根据地址运算规则,此时放大因子为4x2=8,所以此时正好指向二维数组的第1行。和二维数组元素地址计算的规则一样,*p+1指向a[0][1],*(p+i)+j则指向数组元素a[i][j]。

例1

inta[3] [4]={

{1,3,5,7},

{9,11,13,15},

{17,19,21,23}

};

main()

{

inti,(*b)[4];

b=a+1;/* b指向二维数组的第1行, 此时*b[0]或

**b是a[1][0]*/

for(i=1;i<=4;b=b[0]+2,i++)/*修改b的指向, 每次增加2 */

printf("%d\t",*b[0]);

printf("\n");

for(i=0; i<2; i++) {

b=a+i;/* 修改b的指向, 每次跳过二维数组的

一行*/

printf("%d\t",*(b[i]+1));

}

printf("\n");

}

程序运行结果如下:

913 17 21

311 19

转载于:https://www.cnblogs.com/xuq22/archive/2011/05/26/3769330.html

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可 6私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值