谁能给我讲讲二维数组元素的引用啊?都有那几种方式啊?10
发布网友
发布时间:2023-10-13 19:51
我来回答
共5个回答
热心网友
时间:2024-11-14 17:19
你好!!!
举例:首先我们要知道数组的是按线性的顺序存放在一起的,比如a[0][2]和a[1][0]是连在一起的,后面的依次类推、、、
int a[2][3]{1,2,3,4,5,6};
int *p=*a;表示把数组的的第一行第一个元素的地址给指针变量,但是*p=a是错误的!!!
输入数组的元素可以使用数组本身:a[i][j],代表第i行,第j列的元素的值;
其实系统认为二维数组名就是二维指针,我们可以把数组名当做指针使用:
*(*(a+i)+j)表示代表第i行,第j列的元素的值。
要是使用刚才的指针*(p+n),注意此时的n是从0---5,可以输出数组中的任何一个元素,你也许会问:数组时二维的,而指针变量p是一维的,为什么可以输出所有元素呢???刚才不是说了吗??:首先我们要知道数组的是按线性的顺序存放在一起的,比如a[0][2]和a[1][0]是连在一起的,后面的依次类推、、、
一般情况下:都是使用a[i][j],和*(*(a+i)+j)的形式、、、当然还有很多方法,要是都列出来,恐怕要几张纸呢??
你只要把书本好好看看,多想想,自己就有一些认识了。
要是有什么不理解的问题,我们可以交流一下!!
热心网友
时间:2024-11-14 17:19
从根本来说我知道是二种, 因为按下标访问和按指针的访问其实是一样的意义.
楼下说的 a[i][j],和*(*(a+i)+j)方式其实原理是一样的.
一\ 这种是先确认行, 寻址数组元素,是先把二维数组的每一行看成一个一维数组的元素,
然后再去分,每一行统领的那一列又作为一个一维数组.有二个步骤.
就好比给你一个门牌号, 303, 你知道门牌号的意义, 你会直接跑到三楼(按行再去找列)去找第三个房间.
二\还有一种是直接通过列去寻址,只分一次, 直接把二维数组的所有元素看成一个一维数组的元素. 通过偏移量计算每个元素的值. 这时候输出的方式就是p[i * n + j] 的方式了,(n的值是数组的列数) 而不是像第一种是 p[i][j]的方式.
这种方式是给你一个门牌号, 303, 你不知道门牌号的意义, 你会先从一楼开始一间一间的找, 然后二楼,三楼,这时候你发现找到了.
没有时间答的很好,仔细, 如果你初学没多久,看不太懂的话, 还是得自己去查资料学, 或者找好的课件,找老师去问. 这样才能足够确信, 加理解.
我这里能提供的就是,在你学习到理解一定程度后,你还知道还有另外个方向,这时候你可以再去往这个方向,靠自己探索,搞详细,搞明白
热心网友
时间:2024-11-14 17:20
你好!!!
举例:首先我们要知道数组的是按线性的顺序存放在一起的,比如a[0][2]和a[1][0]是连在一起的,后面的依次类推、、、
int a[2][3]{1,2,3,4,5,6};
int *p=*a;表示把数组的的第一行第一个元素的地址给指针变量,但是*p=a是错误的!!!
输入数组的元素可以使用数组本身:a[i][j],代表第i行,第j列的元素的值;
其实系统认为二维数组名就是二维指针,我们可以把数组名当做指针使用:
*(*(a+i)+j)表示代表第i行,第j列的元素的值。
要是使用刚才的指针*(p+n),注意此时的n是从0---5,可以输出数组中的任何一个元素,你也许会问:数组时二维的,而指针变量p是一维的,为什么可以输出所有元素呢???刚才不是说了吗??:首先我们要知道数组的是按线性的顺序存放在一起的,比如a[0][2]和a[1][0]是连在一起的,后面的依次类推、、、
一般情况下:都是使用a[i][j],和*(*(a+i)+j)的形式、、、当然还有很多方法,要是都列出来,恐怕要几张纸呢??
你只要把书本好好看看,多想想,自己就有一些认识了。
要是有什么不理解的问题,我们可以交流一下!!
热心网友
时间:2024-11-14 17:20
对于a[i][j](二维数组的大小为n×m)而言,
首先要搞清楚行指针和列指针
行指针:&a[i]或者a+i指向行,&a[i]=&*(a+i)=a+i
列指针:a[i]或*(a+i)指向列,a[i]等价于*(a+i)
元素的引用方式有如下三种方式
1.通过地址引用二维元素
*(&a[i][j]),
*(a[i]+j),
*(*(a+i)+j),
*(a[0]+m*i+j)
*(&a[0][0]+m*i+j)
(*(a+i))[j]
2.建立一个指针数组引用二维元素
int *p[3],a[3][2],i,j;
for(i=0;i<3;i++)
p[i]=a[i];//p[i]用来存放地址,a[i]为列地址
等价如下
(1) *(p[i]+j) 与*(a[i]+j)对应
(2)*(*(p+i)+j) 与*(*(a+i)+j)对应
(3)(*(p+i))[j] *(p[i]+j) 与*(a[i]+j)对应
(4)p[i][j] 与a[i][j]对应
3.建立一个行指针引用二维数组元素
int a[3][2],(*p)[2];
p=a;
(1) *(p[i]+j) 与*(a[i]+j)对应
(2)*(*(p+i)+j) 与*(*(a+i)+j)对应
(3)(*(p+i))[j] 与(*(a+i))[j]对应
(4)p[i][j] 与a[i][j]对应
例题如下
1.
#include<stdio.h>
main()
{
int score[][4]={{60,70,80,90},{56,89,67,88},{34,78,90,66}};
int i,j;
printf("输入学生号:0-2");
scanf("%d",&i);
printf("the score of No.%d are:\n",i);
for(j=0;j<4;j++)
printf("%d\t",*(*(score+i)+j));//score+i为列指针,*(score+i)为行指针
printf("\n");
}
2.
#include<stdio.h>
main()
{
int a[3][4]={1,3,5,7,9,11,13,15,17,19,21,23};
int *p;
for(p=a[0];p<a[0]+12;p++)//使p依次指向下一个元素,a[i]和*(a+i)是指向列的指针;&a[i]或a+i是指向行的指针
{
if((p-a[0])%4==0)printf("\n");
printf("%4d",*p);//输出p指向的数组元素的值
}
printf("\n");
}
3
#include<stdio.h>
main()
{
int score[][4]={{60,70,80,90},{56,89,67,88},{34,78,90,66}};
int i,j;
printf("输入学生号:0-2");
scanf("%d",&i);
printf("the score of No.%d are:\n",i);
for(j=0;j<4;j++)
printf("%d\t",*(score[i]+j));
printf("\n");
}
4
#include<stdio.h>
main()
{
int score[][4]={{60,70,80,90},{56,89,67,88},{34,78,90,66}};
int i,j,*p;
printf("输入学生号:");
scanf("%d",&i);
printf("the score of No.%d are:\n",i);
for(p=score[i];p<score[i]+4;p++)
printf("%d\t",*p);//p+i指向第i行,*(p+i)指向第i行0列元素*(p+i)+j指向第i行j列元素,是列地址
printf("\n");
}
5.
#include<stdio.h>
main()
{
int score[][4]={{60,70,80,90},{56,89,67,88},{34,78,90,66}};
int i,j,*p;
printf("输入学生号:");
scanf("%d",&i);
printf("the score of No.%d are:\n",i);
for(p=score[i],j=0;j<4;j++)
printf("%d\t",*(p+j));
printf("\n");
}
6
#include<stdio.h>
main()
{
int score[][4]={{60,70,80,90},{56,89,67,88},{34,78,90,66}};
int i,j,(*p)[4];//指针变量p指向包括4个整型元素的一维数组;
p=score;//p指向二维数组0行元素,p+1所指向的元素是p所指向元素的下一行元素;
printf("输入学生号:0-2");
scanf("%d",&i);
printf("the score of No.%d are:\n",i);
for(j=0;j<4;j++)
printf("%d\t",*(*(p+i)+j));//p+i指向第i行,p是行指针,*(p+i)指向第i行0列元素,是列指针。*(p+i)+j指向第i行j列元素,是一个元素的地址
printf("\n");
}
热心网友
时间:2024-11-14 17:21
这个关系到很多,引用有指针引用,这一个比较难一点,还有函数引用,中等难度,再有就是直接引用,用的少