C语言三种传递二维数组的方法

方法一:传递时指指定列数

C语言里面对二维数组的存储是按照一维数组来处理的,二维数组按照行展开的方式按顺序存储,
所以在利用二维数组作为参数传递时,必须指定二维数组的列数,否则函数无法勾画出二维数组的组织形式。只有有了列长度,通过下标a[i][j]时才能得到正确的下标地址,即:

void foo(int a[][3], int m, int n) 
{
   
}

方法二:把参数声明为一个指向数组的指针

#include <stdio.h>

void foo(int (*a)[3], int m, int n) {
    int i = 1;
    int j = 1;
    printf("a[%d][%d]=%d\n", i, j, a[i][j]);
}

int main() {
    int a[2][3] = {
        {1,2,3},
        {4,5,6}
    };
    foo(a, 2, 3);
}

注意:此时还是需要指定二维数组的列长度,不然函数内部还是无法使用二维下标去访问数组

方法三:把参数声明为指向指针的指针

#include <stdio.h>

void foo(int **a, int m, int n) {
    int i = 1;
    int j = 1;
    printf("a[%d][%d]=%d\n", i, j, a[i][j]);
}

int main() {
    int a[2][3] = {
        {1,2,3},
        {4,5,6}
    };
    int * p[3];

    p[0] = a[0];
    p[1] = a[1];
    p[2] = a[2];
    foo(p, 2, 3);
}

posted @ 2023-03-15 14:12  Free152  阅读(2289)  评论(0)    收藏  举报