两种方法: 1.转化为一维数组申请 2.先申请全部行首指针,再按行逐行申请 1.单次申请:
a=(int *)malloc(sizeof(int),(unsigned)m*n); 使用的时候就和一般的二维数组一样。 举个例子给你: #include "stdlib.h" #include "stdio.h" #include <malloc.h> int main() { int i,j; int (*p)[10]; //动态生成二维数组格式就是相当与p[10][10],如果想改,自己该里面 的参数,如果想定义n行2列就为: p=(int (*)[2])malloc(n*2*sizeof(int)); p=(int (*)[10])malloc(10*10*sizeof(int)); for(i=0;i<10;i++) for(j=0;j<10;j++) p[i][j]=i*j; for(i=0;i<10;i++) { for(j=0;j<10;j++) printf("%d,",p[i][j]); printf("\n"); } free(p); return 0; } 2. 多次申请: #include <stdio.h> #include <malloc.h> main() { int i = 0; int j = 0; int line = 0; int row = 0; int **p = NULL; printf("input the line of the array:\n"); scanf("%d", &line); printf("input the row of the array:\n"); scanf("%d", &row); p = (int **)malloc(sizeof(int *) * line); if (NULL == p) { return; } for (i = 0; i < line; i++) { *(p + i) = (int *)malloc(sizeof(int) * row); if (NULL == *(p + i)) { return; } } /*input data*/ for (i = 0; i < line; i++) { for(j = 0; j < row; j++) { p[i][j] = i + 1; } } /*output data*/ for (i = 0; i < line; i++) { for(j = 0; j < row; j++) { printf("%d", p[i][j]); } } /*free every line point*/ for (i = 0; i < line; i++) { free(*(p + i)); p[i] = NULL; } free(p); p = NULL; } 第一种方法数组创建和释放都比较简单,申请的单元都是连续的,第二种单元不一定是连续的存储单元