1、我们首先定义一个二级指针和一个行列变量[int ** array,row,column;]。
2、然后我们编写进入行和列的语句,代码如图所示。
3、接下来我们可以用一维数组打开一维一维数组。
4、接下来,我们使用[array [i] =(int *)malloc(sizeof(int)* column);]来为数组再次生成包含该数组的新数组。
5、然后我们可以为它赋值并输出[代码如图所示]。
6、运行程序后我们可以看到这种效果。
C语言中函数不能直接返回一个二维数组。但是可以通过其他方法实现类似功能:
1、把二维数组定义为全局变量 这样可以直接在另一个函数中调用
2、把二维数组作为指针传入到第一个函数中 然后同样作为指针传到另一个函数中
3、动态分配内存 在赋值函数中动态分配 并用返回值返回,在另一个函数中进行访问
需要动态申请的啊,堆栈上面的数组是不能直接返回的会在函数退出的时候销毁掉
#include
int **returnNum()
{
int **a,i,j;
a = (int**)malloc(5*sizeof(int*));
for(i=0;i<5;++i)
{
a[i] = (int*)malloc(5*sizeof(int));
for(j=0;j<5;++j)
{
a[i][j]=i;
}
}
return a;//error: cannot convert `int (*)[5]' to `int**' in return
}
int main()
{
//int cpy[5][5]=returnNum; // error: invalid initializer
int **cpy=returnNum();
int i,j;
for(i=0;i<5;++i)
{
for(j=0;j<5;++j)
{
printf("%d ", cpy[i][j]);
}
printf("\n");
free(cpy[i]);
}
free(cpy);
return 0;
}
#include
希望对你能有所帮助。
c语言无法返回空间,只能返回指针。
函数内动态申请,返回指针,缺点是容易出现野指针,根据谁申请谁释放原则。
设置全局参数,缺点全局数据稍微多了一些,而且破坏封装思想。