关于c语言指向一位数组指针用法的详细解释(C语言程序设计例题)

图片说明
书中说形参(pointer是一个指向包含4个元素的一位数组指针这我能理解)
1.但是为什么(score[][4]明明是个二维数组,为什么可以将首地址作为一位数组的指针传进函数里?)
2.还有就是(pt是一个float指针,pointer也是指针为什么要写pt=*(pointer+n))
下面有我自己打的简易代码,得到的结果是对的,但是不太明白原理,望大佬为我解惑谢谢

#include<stdio.h>
using namespace std;
int 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:");
    scanf("%d",&m);
    printf("m:%d\n",m);
    p=search(score,m);
    for(i=0;i<4;i++){
        printf("%5.2f\t",*(p+i));
    }
    return 0;
}
float *search(float (*pointer)[4],int n){
    float *pt;
    pt=*(pointer+n); 
    /*这里为什么要加*取pointer所指向的元素(pointer不是自己的值就是地址吗)*/
    return(pt);
}

这是利用二维数组的首地址位移进行数组元素的索引,看做指针的话,取值的时候就要加*啊

下面的内容来自网络

例如:二维数组arr[3][4]:可以看作是3个一维数组,那么一维数组的索引是0-2.每一个一维数组中存放4个元素.索引都是从0开始,一维数组中的元素的索引是0-3
出处

 C语言规定,作为数组类型放在函数参数里可以当作指针来用
pt=*(pointer+n)
也可以写
pt = pointer[n]