定义较大数组时不出结果

本想定义一个较大的数组用于数列求值,运行竟然没有结果,原代码和运行结果如图:

//数列求值 
#include<iostream>
using namespace std;
int main(void){
	long long a[30000000];
	a[0] = 1;
	a[1] = 2;
	a[2] = 1;
	for(int i = 3;i < 10;i++){
		a[i] = 2*(a[i - 3]) + a[i - 2] + 5*(a[i -1]);
		cout<<a[i]<<" ";
	} 
	return 0;
}

找到的解决方法如下:

1.定义成全局变量
最简单的办法就是定义成全局变量啦,这样的话就存放在静态存储区,就不是在堆栈里面,问题就解决啦!

2.动态分配数组

就是使用malloc-free、new-delete定义数组,用了malloc在程序结束要用free释放空间,new要用delete。
————————————————
版权声明:本文为CSDN博主「「已注销」」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_43870123/article/details/100543046

因此我把定义数组那一行放到了主函数外面,完美解决问题~在此做一个记录,以备查看。

我同样尝试了一下动态分配:

//数列求值 
#include<iostream>
using namespace std;
int main(void){
	//动态分配 
	long long* a=(long long *)malloc(sizeof(long long)*30000000);
	a[0] = 1;
	a[1] = 2;
	a[2] = 1;
	for(int i = 3;i < 10;i++){
		a[i] = 2*(a[i - 3]) + a[i - 2] + 5*(a[i -1]);
		cout<<a[i]<<" ";
	} 
	//释放动态开辟的空间
    free(a);
	return 0;
}

也解决了问题~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值