C语言随机矩阵乘法,数据输入过大崩溃,求大神指教

每次输入1000*1000的矩阵肯定崩溃,原因不明
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main()
{ clock_t start,finish;
double totaltime;
start=clock();
int line1, column1, column2;
int i, j, k;
printf("输入第一个矩阵的行数:\n");
scanf("%d", &line1);
printf("输入第一个矩阵的列数:\n");
scanf("%d", &column1);
printf("输入第一个矩阵的列数:\n");
scanf("%d", &column2);
long arr1[line1][column1], arr2[column1][column2],arr3[line1][column2];
//printf("输入第一个矩阵的元素(%d*%d):\n",line1,column1);
srand((unsigned)time(NULL));
for (i = 0; i < line1; i++)
{
for (j = 0; j < column1; j++)
{
arr1[i][j] =(long)rand()%10+1;
}
}
//printf("输入第二个矩阵的元素(%d*%d):\n", column1, column2); 因为在这里矩阵的乘法会要求第一个的列与第二个行相等
for (i = 0; i < column1; i++)
{
for (j = 0; j < column2; j++)
{
arr2[i][j] =(long)rand()%10+1;
}
}
long ret;
for (i = 0; i < line1; i++)
{
for (j = 0; j < column1; j++)
{
ret = 0;
for (k = 0; k < column2; k++)
{
ret += arr1[i][k] * arr2[k][j]; //按照矩阵的乘法规则进行运算
}
arr3[i][j] = ret;
}
}
for (i = 0; i<line1; i++)
{
for (j = 0; j<column1; j++)
printf("%ld ", arr1[i][j]);
printf("\n");
}
printf("\n");
for (i = 0; i<column1; i++)
{
for (j = 0; j<column2; j++)
printf("%ld ", arr2[i][j]);
printf("\n");
}
printf("输出的两个矩阵的乘法运算的结果是:\n");
for (i = 0; i<line1; i++)
{
for (j = 0; j<column2; j++)
printf("%ld ", arr3[i][j]);
printf("\n");
}

finish=clock();
totaltime=(double)(finish-start)/CLOCKS_PER_SEC;
printf("%f",totaltime);
printf("\n");
//system("pause");
return 0;
}

占用内存过大,超出允许范围。至少200万个数据。建议用文件存储矩阵,同时输出到文件,内存中不要定义这么庞大的数组。
long arr1[line1][column1], arr2[column1][column2],arr3[line1][column2];
定义变长数组,一般也是不允许的,应该用malloc命令临时请求内存,并且在退出程序之前,释放内存。
温馨提示:内容为网友见解,仅供参考
第1个回答  2017-11-09
佳人(杜甫)
第2个回答  2017-11-09
苏武庙(温庭筠)
第3个回答  2017-11-09
香菱(甄英莲):臻儿
第4个回答  2017-11-09
送李少府贬峡中王少府贬长沙(高适)
第5个回答  2017-11-09
登楼(杜甫)
相似回答