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

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

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

C语言里面对二维数组的存储是按照一维数组来处理的,二维数组按照行展开的方式按顺序存储,

所以在利用二维数组作为参数传递时,必须指定二维数组的列数,否则函数无法勾画出二维数组的组织形式。只有有了列长度,通过下标a[i][j]时才能得到正确的下标地址,即:

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

{

}

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

#include

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

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);

}

相关推荐

蹉跎什么什么的成语

蹉跎什么什么的成语

📅 07-02 👁️ 4836
猫咪哈气是什么原因?揭示猫咪的情绪与健康信号
从困难重重到创造奇迹 历数FAST五年半建设之路