C语言 指针函数 行指针 列指针解决办法

C语言 指针函数 行指针 列指针
大恨:小弟在VC6.0上写的程序,粘贴在这里格式都是左对齐了,哎~~~
小弟最近一直对行指针和列指针理解有些吃力,下面这个程序是书本上的,小弟对其中有些部分理解不好,恳请大神不惜赐教~~~C语言 指针函数 行指针 列指针解决办法

#include<stdio.h>
float *search(float (*p)[4])//该函数的返回值是一个指向float类型的指针,这里的形参p是一个行指针
{                                            
int i;
float *pt;
pt=*(p+1);//p是一个行指针,p+1当然也是行指针,那么*(p+1)则是一个列指针
for(i=0;i<4;i++)
{
if(*(*p+i)<60)//*p+i表示第0行第i列指针,*(*p+i)表示第0行第0列的元素
{
pt=*p;//如果该行中某个元素的值小于60,那么返回该行的第一个元素的指针,也就是返回一个列指针
}
}
return pt;//如果没有,那么返回p所指向的下一行首元素的指针,当然也是列指针
}

void main()
{
float score[][4]={70,52,68,89,88,74,85,96,64,55,53,78};//我可以认为score数组是1行12列吗(因为这样的话,我可以通过1个列指针访问数组的所有元素)?这样理解正确吗?
float *ptr;                                            
int i,j;
for(i=0;i<3;i++)
{
ptr=search(score+i);//search函数的形参是一个行指针,返回值也是一个列指针,那么ptr也是一个列指针
if(ptr==*(score+i)) //如果两者相等,则说明score数组中某元素的值<60
{                   //如上所述:如果我可以把score数组看成1行12列,那么请问这里的ptr是将跟score数组中每个元素的值相比较,是应该这样理解吗?
printf("No.%d score: ",i+1);
for(j=0;j<4;j++)
{
printf("%5.2f ",*(ptr+j));//ptr是一个列指针,那么ptr+j表示该行第j个元素的地址
}                             //*(ptr+j)则表示该行第j个元素的值
printf("\n");
}
}
}
------解决思路----------------------
什么行指针、列指针的,我觉得这么多反而会让人更加糊涂。
如果有需求需要使用行、列的概念,比如
#define ROW 100
#define COL 100
那你定义数组时,就可以定义成 float p[ROW * COL]

比如你要访问第15行第8个数字
就使用 p[ROW * 15 + 7]

本质上定义成 float p[ROW * COL] 和  float p[ROW][COL] 是一样的,内存中都是连续的 ROW * COL = 10000长度的空间,行和列的概念只是用以定位其中的某个位置而已,而且容易搞混了。
------解决思路----------------------
引用:
什么行指针、列指针的,我觉得这么多反而会让人更加糊涂。
如果有需求需要使用行、列的概念,比如
#define ROW 100
#define COL 100
那你定义数组时,就可以定义成 float p[ROW * COL]

比如你要访问第15行第8个数字
就使用 p[ROW * 15 + 7]

本质上定义成 float p[ROW * COL] 和  float p[ROW][COL] 是一样的,内存中都是连续的 ROW * COL = 10000长度的空间,行和列的概念只是用以定位其中的某个位置而已,而且容易搞混了。


比如你要访问第15行第8个数字 应该是 p[ROW*14 + 7]