如果需要开一个很大的数组,比如10000000,如果在函数内部定义的话编译的时候总是出现“[Error] size of array ‘flag’ is too large ”的错误(包括main()函数),但是题目要求就得是这么大范围的数组,我们没有办法缩小数组范围,这样可能会导致一些测试点过不了,所以,遇到这样的问题该怎么解决呢?
局部非静态的数组,空间在程序的栈上分配,不同平台的栈大小不同:SunOS/Solaris是8M,Linux是10M,Windows是1M,AIX是64M,都是可以调整的。
解决方法
1.定义成全局变量
最简单的办法就是定义成全局变量啦,这样的话就存放在静态存储区,就不是在堆栈里面,问题就解决啦!
2.动态分配数组
就是使用malloc-free、new-delete定义数组,用了malloc在程序结束要用free释放空间,new要用delete。
我自己还是喜欢定义成全局变量啦,这样很简单!