如果定義的數組過大,編譯器不通過,以前知道動態分配內存,或者修改內存模式解決
今天突然看到一個程序,直接把數組定義成全局數組,便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;
}
那樣定義是在堆上分配空間,堆空間大,如果是局部聲明數組,是在棧上分配,可能超出棧容量