开篇引题,c语言学习完快半年了,该学的学到了,该忘的也大概忘得差不多了,今儿突发奇想,本不能丢,顾通过博客的形式来热热。望博友们不要笑话。
二维数组,重在其访问方式以及其的物理地址的理解。
以int a[3][5]为例:
![如图]
(https://img-blog.csdn.net/20150331192114229)
如上图:
二维数组归根结底就是线性一维的,其相应数据的存储都是以连续地址的方式进行的。
那么其相应的访问方式如下:
地址2008到2012存储实数3(此处仅以数值代替地址)
那么相应的访问方式为:
1: a[0][2]
2:*(a[0]+2)
3: * ( *(a+0)+2)
指针数组:
int *p[5];
每一个元素都是指向实型数据的指针。
如要将二维数组赋给一指针数组:
int *p[2];
int a[2][4];
for(i=0;i<2;i++)
p[i]=a[i];
行指针:
int (*p)[5] 行指针:带括号
指向一个整型的一维数组,这个一维数组的长度是5(步长值),也可以说是p的步长。也就是说执行p+1时,p要跨过5个整型数据的长度
赋值方式:
int a[3][4];
int (*p)[4];
p=a;
for(i=0;i<3;i++)
{
// 可对数组的每一行(元素)进行赋值与访问;
}
//行指针与二维数组哈
char a[3][10];
char (*p)[10];
p = a;
printf("input:\n\n");
fflush(stdin);
for (int i = 0; i < 3; i++)
{
gets(*p);
p++;
}
p = a;
for (int i = 0; i < 3; i++)
{
puts(*p);
p++;
}
printf("\n\n\n");
for (int i = 0; i < 3; i++)
{
puts(a[i]);
p++;
}