二维数组的行地址、列地址,与元素的存储

1、连续存储

2、二维数组的行地址与列地址

1)行地址

1、二维数组中,数组名a的值,是数组a首元素a[0][0]的地址,即&a[0][0],第一行第一个元素的地址;

2、二维数组中,数组名a+1是数组a的元素a[1][0]的地址,即&a[1][0],第二行第一个元素的地址;

2)列地址

1、二维数组中,a[0]的值,即该数组的首元素a[0][0]的地址,即&a[0][0];

2、二维数组中,a[0]+1的值,是数组元素a[0][1]的值,即&a[0][1];

3)混合一下

1、二维数组中,“a[0]+1”是指向数组元素a[0][1]的地址,“a[1]+2”是指向数组元素a[1][2]的地址;

2、同样的,二维数组中,“*(a+1)+2”是指向数组元素a[1][2]的地址,与“a[1]+2”相等;

注:

*(a+1)表示第2行的行地址;

*a+1表示第一行第二个元素的地址;

3、二维数组中,*(*(a+1)+2))是数组元素a[1][2]的!!!

扫描二维码关注公众号,回复: 2382561 查看本文章


 

/*
*copyright(c) 2018,HH
*All rights reserved.
*作 者:HH
*完成日期:2018年7月25日
*版本号:v1.0
*
*问题描:二维数组,元素地址的表示,行列地址的表示;
*输入描述:;
*程序输出:
*/

#include <stdio.h>
int main()
{
    int a[2][3]={{1,2,3},{4,5,6}};
    int i,j;
    int *p1,*p2,*p3,*p4,*p5,*p6;
    printf("array a is :\n");
    for(i=0;i<2;i++)
    {
        for(j=0;j<3;j++)
        {
            printf("%d ",a[i][j]);
        }
        printf("\n");
    }
    printf("array b is :\n");
    p1=a;//二维数组的数组名,即首元素a[0][0]的首地址;
    p2=a+1;//a+1是数组a的元素a[1][0]的地址,即&a[1][0]
    p3=a[0];//同a[0][0]的地址,即第一行第一个元素的地址
    p4=a[1];//同a[1][0]的地址,即第二行第一个元素的地址
    printf("p1=a指向的值是:%d;地址是:%d\n",*p1,p1);
    printf("p2=a+1指向的值是:%d;地址是:%d\n",*p2,p2);
    printf("p3=a[0]指向的值是:%d;地址是:%d\n",*p3,p3);
    printf("p4=a[1]指向的值是:%d;地址是:%d\n",*p4,p4);
    p5=a[0]+1;//指向第一行,第二列元素的地址;
    p6=a[1]+1;//指向第二行,第一列元素的地址;
    printf("p5=a[0]+1指向的值是:%d;地址是:%d\n",*p5,p5);
    printf("p6=a[1]+1指向的值是:%d;地址是:%d\n",*p6,p6);
    printf("*(a+1)指向的地址是:%d\n",*(a+1));
    printf("*(*(a+1))指向的值是:%d\n",*(*(a+1)));
    printf("*(a+1)+2指向的地址是:%d\n",(*(a+1)+2));
    printf("*(a+1)+2指向的值是:%d\n",*(*(a+1)+2));
    printf("*a+2指向的值是:%d;地址是:%d\n",*(*a+2),*a+2);
    return 0;
}

3)行地址,列地址的等价写法

注:在二维数组a[i][j]中,a[i]是“行名”,等价于指针;

a[0]等价于a,都表示指针;

a[1]等价于a+1,都表示指针;

a[1]+1等价于*(a+1)+1,都表示指针

注意防止越界!

猜你喜欢

转载自blog.csdn.net/pl0020/article/details/81199164
今日推荐