本程序简单的展示了动态分配二维数组,同时为rand()设置随机种子srand((int)time(0)),来产生连个不重复的随机序列。
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h>
// 打印二维数组
void print(int **array,int rows,int columns)
{
int i,j;
for(i=0;i<rows;i++)
for(j=0;j<columns;j++)
printf("%d ",array[i][j]);
}
void main()
{
int nrows,ncolumns;
int mrows,mcolumns;
int **Array;
int **mArray;
int i,j;
printf("please input nrows&ncolumns:/n");
scanf("%d%d",&nrows,&ncolumns);
//分配第一个二维数组的空间
Array=(int **)malloc(nrows*sizeof(int *));
for(i=0;i<ncolumns;i++)
Array[i]=(int *)malloc(sizeof(*Array));
printf("please input mrows&mcolumns:/n");
//分配第二个二维数组的空间
scanf("%d%d",&mrows,&mcolumns);
mArray=(int **)malloc(mrows*sizeof(int *));
for(i=0;i<mcolumns;i++)
mArray[i]=(int *)malloc(sizeof(*mArray));
srand((int)time(0)); //important,否则两次产生的随机序列相同
//处理第一个二维数组
for(i=0;i<nrows;i++)
{
for(j=0;j<ncolumns;j++)
{
if(rand()%2==0)
{
Array[i][j]=0;
}
else Array[i][j]=1;
}
}
print(Array,nrows,ncolumns);
printf("/n");
free(Array);
//处理第二个二维数组
for(i=0;i<mrows;i++)
{
for(j=0;j<mcolumns;j++)
{
if(rand()%2==0)
{
mArray[i][j]=0;
}
else mArray[i][j]=1;
}
}
print(mArray,nrows,ncolumns);
printf("/n");
free(mArray);
}