二维数组与指针的一个例子

刚在网上看到的一个题目,觉得有点意思就做了一下:输入m,n,返回一个m*n的零矩阵。

方案一:用一维指针解决,比较简单

#include<stdio.h> #include<malloc.h> int main() {  int m,n,i,j,*p;  printf("input m,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(" ");  } }

方案二:可能觉得上面的一维指针,不能形象的表达二维数组,所以底下一个用二维指针解决。

#include<stdio.h> #include<stdlib.h> int main() {  int m,n,i,j,**p;  printf("input m,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(" ");  } }

原文地址:https://www.cnblogs.com/ITyannic/p/3998326.html