#include <stdio.h>
void main()
{
float score[][4] ={{60,70,80,90},{56,89,67,88},{34,78,90,66}};
float *search(float(*pointer)[4],int n);
float *p;
int i,m;
printf("enter the number of student:");
scanf("%d",&m);
printf("The scores of No.%d are:\n",m);
p = search(score,m);
for(i = 0;i<4;i++)
{
printf("%5.2f\t",*(p+i));
}
printf("\n");
}
float *search(float(*pointer)[4],int n)
{
float *p;
p = *(pointer+n);//重点解析此行代码。
return p;
}
(*p)[n]和*p[n]解析:
很多新人不明白上面那行代码,本人也想了好久最后才想通了。
平常情况*p = fun,fun存放某类型数值,(*p)[n]即可用fun[n]代替,即有一个n维的数组,存放某种类型的数值,而p为指针,存放着指向fun的地址。则又fun本身是一个地址,p存放的地址是指向某个地址的地址,固有上面的p= *(pointer+n)。如果p+1,则是下行一维度的数据,*(p)+1则是原维度的下一个数据。
*p[n]就简单明了,p[n]为数组,存放地址,存取其实也是二次寻址,不过p本身属于单一维度的数组故没有上面那么难理解。