我想使用 4 维数组。
int A[80][80][80][80];
当我尝试使用它时,我得到分段错误(核心转储)。例如:
for(i=0;i<80;i++)
for(j=0;j<80;j++)
for(k=0;k<80;k++)
for(l=0;l<80;l++)
A[i][j][k][l]=i+j+k+l;
printf("%d\n",A[0][1][2][3]);
我想使用 4 维数组。
int A[80][80][80][80];
当我尝试使用它时,我得到分段错误(核心转储)。例如:
for(i=0;i<80;i++)
for(j=0;j<80;j++)
for(k=0;k<80;k++)
for(l=0;l<80;l++)
A[i][j][k][l]=i+j+k+l;
printf("%d\n",A[0][1][2][3]);
这是一个非常大的数组 -40,960,000 * sizeof(int)
字节。如果你在堆栈上声明它,你肯定会溢出可用的堆栈内存。尝试堆分配它。
int* A = malloc(80 * 80 * 80 * 80 * sizeof(int));
/* use A */
free(A);
或者,更好,正如约翰·博德所建议的那样
int (*A)[80][80][80] = malloc( sizeof *A * 80 );
for (i=0; i<SIZE; i++) {
for (j=0; j<SIZE; j++) {
for (k=0; k<SIZE; k++) {
for (l=0; l<SIZE; l++) {
A[i][j][k][l] = i+j+k+l;
}
}
}
}
printf("%d\n",A[0][1][2][3]);
free(A);