用malloc动态申请一个二维数组的三种方法

来源:互联网 发布:网络打印机ip地址 编辑:程序博客网 时间:2024/06/14 11:51

方法一:利用二级指针申请一个二维数组。

[cpp] view plain copy
print?
  1. #include<stdio.h>  
  2. #include<stdlib.h>  
  3.   
  4.   
  5. int main()  
  6. {  
  7.     int **a;  //用二级指针动态申请二维数组  
  8.     int i,j;  
  9.     int m,n;  
  10.     printf("请输入行数\n");  
  11.     scanf("%d",&m);  
  12.     printf("请输入列数\n");  
  13.     scanf("%d",&n);  
  14.     a=(int**)malloc(sizeof(int*)*m);  
  15.     for(i=0;i<m;i++)  
  16.     a[i]=(int*)malloc(sizeof(int)*n);  
  17.     for(i=0;i<m;i++)  
  18.     for(j=0;j<n;j++)  
  19.     printf("%p\n",&a[i][j]);     //输出每个元素地址,每行的列与列之间的地址时连续的,行与行之间的地址不连续  
  20.     for(i=0;i<m;i++)  
  21.     free(a[i]);  
  22.     free(a);  
  23.     return 0;  
  24. }  


方法二:用数组指针形式申请一个二维数组。

[cpp] view plain copy
print?
  1. #include<stdio.h>  
  2. #include<stdlib.h>  
  3.   
  4.   
  5. int main()  
  6. {  
  7.       int i,j;  
  8.   //  申请一个3行2列的整型数组  
  9.     int (*a)[2]=(int(*)[2])malloc(sizeof(int)*3*2);  
  10.     for(i=0;i<3;i++)  
  11.     for(j=0;j<2;j++)  
  12.     {  
  13.          
  14.        printf("%p\n",&a[i][j]);  
  15.   
  16.     } //输出数组每个元素地址,每个元素的地址是连续的  
  17.     free(a);  
  18.     return 0;  
  19. }  


方法三:用一个单独的一维数组来模拟二维数组。

[cpp] view plain copy
print?
  1. #include <stdio.h>  
  2. #include <stdlib.h>  
  3. void main()  
  4. {  
  5. int nrows,ncolumns;  
  6. int *Array;  
  7. int i,j;  
  8. printf("please input nrows&ncolumns:\n");  
  9. scanf("%d%d",&nrows,&ncolumns);  
  10. Array=(int *)malloc(nrows*ncolumns*sizeof(int *));  
  11. for(i=0;i<nrows;i++)  
  12. {  
  13. for(j=0;j<ncolumns;j++)  
  14. {  
  15. Array[i*nrows+j]=1;  
  16. printf("%d ",Array[i*nrows+j]); //用 array3[i * ncolumns + j] 访问第 i, j 个成员  
  17. }  
  18. printf("\n");  
  19. }  
  20. free(Array);  
  21. }  









转载自:http://blog.csdn.net/fengxinlinux/article/details/51541003

原创粉丝点击