初学者求教 关于数组过大的问题

如果定义的数组过大,编译器不通过,以前知道动态分配内存,或者修改内存模式解决
今天突然看到一个程序,直接把数组定义成全局数组,便ok了 why?
#include
int c[1001][1001];
int main(){
int n,m,i,j;
char a[1001],b[1001];
scanf("%d %d",&n,&m);
scanf("%s",a);
scanf("%s",b);
for(i=1;i<=m;i++) c[i][0]=0;
for(i=0;i<=n;i++) c[0][i]=0;
for(i=0;i for(j=0;j if(a[i]==b[j])
c[i+1][j+1]=c[i][j]+1;
else if(c[i][j+1]>=c[i+1][j])
c[i+1][j+1]=c[i][j+1];
else c[i+1][j+1]=c[i+1][j];
}
printf("%d",c[n][m]);
return 0;
}

那样定义是在堆上分配空间,堆空间大,如果是局部声明数组,是在栈上分配,可能超出栈容量

栈空间有限制,全局对象分配在数据段,但更好的方式是分配在堆上,用malloc/free

全局变量不使用堆栈,可以分配很大,但是这样做有很多问题,比如说如果你要是实现一个递归算法,那么就不方便了。
最好还是动态分配。

全局变量在放在堆上,局部变量放在栈上,栈大小限制比较小,堆比较大。