斐波那契数列
admin
2024-05-06 14:01:03
0

目录

斐波那契数列是什么?

第一种解法(递归法):

C++递归法求斐波那契数列:

第一种解法的效率:

第二种解法(记忆化递归/动态规划):

C++记忆化递归/动态规划求斐波那契数列:

第二种解法的效率:

第三种解法(递推):

C++递推解法:

第三种解法的效率:

总结:


斐波那契数列是什么?

一、斐波那契数列指的是这样一个数列:1、1、2、3、5、8、13、21、…… 这个数列从第三项开始,每一项都等于前两项之和。

二、应用:通常在个别股票中不是太准确,通常在指数上有用。当市场行情处于重要关键变盘时间区域时,这些数字可以确定具体的变盘时间。使用斐波那契数列时可以由市场中某个重要的阶段变盘点向未来市场推算,到达时间时市场发生方向变化的概率较大。

第一种解法(递归法):

  利用C++求解斐波那契数列第N项数字是什么?我们可以用C++算法,递归法来进行表示.我们知道,斐波那契数列的每一项数字都等于前面两项数字之和,那么用计算机函数来表示,若fun为求斐波那契数列的第N项的函数,那么fun(N)=fun(N-1)+fun(N-2).

  而且我们知道,斐波那契数列数列的第一项和第二项都为1,但是我们在算fun(2)的时候,需要fun(1)+fun(0).第一项数字为1是肯定的,那第0项数字呢?我们就将它姑且当作为0,也可以解决这个问题!

C++递归法求斐波那契数列:

#include //万能头文件 
using namespace std; //批准使用std 
int fun(int n){ //递归函数,求斐波那契数列的第N项数字 if(n==0) //如果是第0项数字 return 0; //返回0 if(n==1) //如果求第一项数字 return 1; //返回1 return fun(n-1)+fun(n-2); //进行递归式调用 
}
int main(){ //主函数 while(1){ //无限循环输入 int n; //定义整数,代表斐波那契数列的第n项数字 cin>>n; //输入n cout<

第一种解法的效率:

fun(n)=

fun(n-1)=     fun(n-2)=

fun(n-1-1)=   fun(n-1-2)=   fun(n-2-1)=  fun(n-2-2)=

.........................................................................................................................

fun(2)=                   ............................................

fun(1)=1        fun(0)=0            .................................................

  最后得出结论,第一种解法普通递归法的时间复杂度为O(2^n).时间复杂度实在是太大了,虽然这样写代码很简短,比其他两种算法都短,但是由于时间效率太慢,不建议使用!

第二种解法(记忆化递归/动态规划):

 第一种普通递归法为什么那么的慢呢?那是因为它重复计算了很多个以前早就已经计算过的值,相当于重复计算,所以时间非常的慢.我们要怎么优化呢?当然是避免重复运算了!怎么避免呢?自然是将我们计算过的值存下来,第二次还需要这个值的时候不需要计算了,直接把之前存下来的那个值返回回去就可以了!

  我们刚开始,需要进行初始化,就是将这个记录所有需要计算的值的这个数组初始化(第i个下标的值代表斐波那契数列的第i项数字的值),初始化为-1!为什么呢?这样体现了做标记的作用,代表这个下标所存的斐波那契数列的第i项数字的值还没有算过.这样在递归过程中,如果是-1,代表没有算过,进行赋值,如果算过来,不需要递归重复计算了,直接将这个的值返回回去就可以了!

  因为我们知道斐波那契数列的第一项和第二项是什么,所以在最开始就要进行赋值f[0]=0(第0项自然为0)f[1]=1;f[2]=1;然后就可以进行递归了!

  这种算法既可以称为"记忆化递归"(毕竟将算过的东西存起来,就是记录下来了),它还有一个名字,是一种很通用的算法"动态规划"!

C++记忆化递归/动态规划求斐波那契数列:

#include  //万能头文件 
using namespace std; //允许使用std里面的函数及类 
long long f[5000000]; //记忆化的数组 
long long fun(int n){ //求斐波那契数列的第n项数字 if(n==0) //如果是第0项 return 0; //返回值为0 if(n==1) //如果求第一项 return 1; //那么返回值为1 if(f[n]==-1) //如果这个值没有计算过 f[n]=fun(n-1)+fun(n-2); //进行递归存储计算 return f[n]; //计算过的话就直接返回 
}
int main(){ //主函数 memset(f,-1,sizeof(f)); //将f这个数组里面的每一个值赋值为-1 f[0]=0; //将第0项赋值为0 f[1]=1; //将第1项赋值为1 f[2]=1; //将第2项赋值为1 while(1){ //无限循环输入 int n; //定义整数,代表斐波那契数列的第n项数字 cin>>n; //输入n cout<

第二种解法的效率:

 将每一个所计算出来的值记录下来,时间复杂度为O(N^2).已经算是非常快的了!比之前的普通递归快了很多倍了!

第三种解法(递推):

  我们在第二种解法中已经看到,可以将值存起来进行计算,不过第二种方法是自上而下来进行计算,和第一种普通递归一样,不过省略了重复的计算步骤.

  而我们第三种解法,是自下而上计算:

  我们都知道,第一个数为1,第二个数也为1,可以存入数组f里面,那么f[3]是不是等于f[1]+f[2]=2了呢?算出了f[3],f[4]就等于f[2]+f[3]=3了!

  这样自下而上计算非常的简洁迅速,快到了极点,堪称斐波那契数列最快的算法之一了.

C++递推解法:

#include //万能头文件 
using namespace std; //允许使用std里面的函数及类 
long long f[5000000]; //记忆化的数组
int main(){ //主函数 long long n; //定义整数,代表斐波那契数列的第n项数字 f[1]=f[2]=1; //将斐波那契数列的第一项和第二项初始化为1 cin>>n; //输入n for(long long i=3;i<=n;i++) //从第三项开始自下而上计算 f[i]=f[i-2]+f[i-1]; //f[i-2]和f[i-1]的值绝对是算出来了的 cout<

第三种解法的效率:

  快,非常快,快到无与伦比!只有O(N)的时间复杂度(无论斐波那契数列的多少项,都可以很快算出来,当然要配上一个高精度),而且代码是如此的简短! 

总结:

  对于求斐波那契数列的算法中,最快的是递推解法O(n),最慢的就是普通递归法O(2^n).所以建议大家以后尽量用一些高效又简洁的算法来解决问题!

相关内容

热门资讯

赚翻了!有人5年前买了2700... 花105万元买黄金 持有5年 现在能赚多少钱? 2月13日 记者从武商MALL·世贸获悉 有顾客于近...
新股消息 | 琻捷电子港股IP... 来源:智通财经网 2月14日,中国证监会国际合作司发布《关于琻捷电子科技(江苏)股份有限公司境外发行...
广东唯一!深圳入选首批“电影+... 深圳商报·读创客户端首席记者 刘琼 深圳迎来“电影+”消费新机遇!2月12日,国家电影局、商务部联合...
新点软件:累计回购约183万股 每经AI快讯,新点软件2月13日晚间发布公告称,截至本公告披露日,公司已完成本次回购。公司通过上海证...
AI太火了,除夕夜也不打烊!八... 【导读】除夕夜开讲AI,卖方分析师春节八天路演排满 中国基金报记者 孙越 随着马年春节进入倒计时,卖...
NVMe-oF 存储区域网络系... 全球领先的市场报告出版商环洋市场咨询(Global Info Research)最新发布【2026年...
一次算力政策研讨实录:算力调度... 算力调度的复杂度远超水电的调度,全国算力调度“一张网”的建设,是通过政府搭台、标准引领、市场运作的综...
容光投资创始合伙人卢安平:坚守... 时序更替,春归华夏,马年新春的钟声即将敲响。结合我过去20多年在资本市场中的感悟与理解,和读者朋友们...
开年三家券商齐接债券业务罚单,... 财联社2月14日讯(记者 高艳云)债市严监管持续加码,春节前最后一个交易日对券商债券业务违规集中“亮...
北京国管丨市级政府投资基金已投... 2月13日,由北京国管管理的北京市人工智能产业投资基金、北京信息产业发展投资基金共同投资的北京海致科...
镜观中国·新华社国内新闻照片一... 新华社照片,北京,2026年2月14日 这是2月13日拍摄的渤中26-6油田开发项目(二期)导管架安...
群核科技港股上市获证监会备案,... 来源:澎湃新闻 “杭州六小龙”中的群核科技港股IPO迎来新进展,获中国证监会备案,拟冲刺“全球空间智...
【环球财经】IEA下调2026... 转自:新华财经 新华财经布鲁塞尔2月13日电(记者黄晓兰)国际能源署(IEA)12日发布石油市场报告...
格鲁吉亚国家银行获准进入中国银... 格鲁吉亚国家银行2月12日宣布,该行已获准进入全球规模最大、最重要的金融市场之一——中国银行间债券市...
原创 委... 在当今的国际能源市场,委内瑞拉的石油资源成了一个极其尴尬的香饽饽。美国通过军事手段成功地控制了委内瑞...
原创 美... 在1月底路透社等媒体发布消息称美国将逐步取消稀土价格下限后,美国能源部表示“消息不属实”,与该消息相...
前字节高管创业教育类出海项目,... 文|富充 编辑|苏建勋 2024年11月,李可佳、吴俊东、张栖铭决定一起创业,做一款“帮助用户终身学...
成立四年之际,泉果基金迎来新一... 来源:新浪基金 泉果基金在迈入发展第四年之际迎来新一任总经理。 2月14日,泉果基金发布的公告显示,...
原创 美... 关税加征,美国先行。这几年,美国在贸易上动作频频,尤其是针对中国的商品,一层又一层地加征关税。回想2...
楚雄滇中有色金属有限责任公司企... 2026年2月13日,楚雄滇中有色金属有限责任公司企业科协正式挂牌成立,这是企业深化科技创新、凝聚科...