标签:io for sp c amp r size bs 简单
刚在网上看到的一个题目,觉得有点意思就做了一下:输入m,n,返回一个m*n的零矩阵。
方案一:用一维指针解决,比较简单
#include<stdio.h> #include<malloc.h> int main() { int m,n,i,j,*p; printf("input m,n\n"); scanf("%d%d",&m,&n); p = (int *)malloc(m*n*sizeof(int)); //malloc(int size):动态分配内存 for(i=0;i<m;i++){ for(j=0;j<n;j++){ printf("%d ",*(p+i*m+j)); } printf("\n"); } }
方案二:可能觉得上面的一维指针,不能形象的表达二维数组,所以底下一个用二维指针解决。
#include<stdio.h> #include<stdlib.h> int main() { int m,n,i,j,**p; printf("input m,n\n"); scanf("%d%d",&m,&n); p=(int **)malloc(m*sizeof(int*)); for(i=0;i<m;i++){ p[i]=(int *)malloc(n*sizeof(int)); } for(i=0;i<m;i++){ for(j=0;j<n;j++){ printf("%d ",p[i][j]); } printf("\n"); } }
标签:io for sp c amp r size bs 简单
原文地址:http://www.cnblogs.com/ITyannic/p/3998326.html