日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

斐波那契数列 递推 递归 备忘录 动态规划

發(fā)布時(shí)間:2025/6/15 编程问答 13 豆豆
生活随笔 收集整理的這篇文章主要介紹了 斐波那契数列 递推 递归 备忘录 动态规划 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

當(dāng)n=0時(shí),f(n) = 0 ? ??

當(dāng)n=1時(shí),f(n) = 1

當(dāng)n>1時(shí),f(n) = f(n-1) + f(n-2)


遞歸算法:

[cpp]?view plaincopy
  • int?fun(int?n)??
  • {??
  • ????if(n?<=?0)??
  • ????????return?0;??
  • ????if(n?==?1)??
  • ????????return?1;??
  • ??
  • ????return?fun(n-1)+fun(n-2);??
  • }??

  • 備忘錄方法:

    [cpp]?view plaincopy
  • #include?<iostream>??
  • using?namespace?std;??
  • ??
  • const?int?N?=?100;??
  • int?f[N];??
  • ??
  • int?fun(int?n)??
  • {??
  • ????if(f[n]>=0)??
  • ????????return?f[n];??
  • ??
  • ????if(n?==?0)??
  • ????{??
  • ????????f[0]?=?0;??
  • ????????cout<<"0"<<endl;??
  • ????????return?f[0];??
  • ????}??
  • ??
  • ????if(n?==?1)??
  • ????{??
  • ????????f[1]?=?1;??
  • ????????cout<<"1"<<endl;??
  • ????????return?f[1];??
  • ????}??
  • ??
  • ????cout<<n<<endl;??
  • ????f[n]?=?fun(n-1)?+?fun(n-2);??
  • ????return?f[n];??
  • }??
  • ??
  • int?main()??
  • {??
  • ????for?(int?i=0;?i<N;?i++)??
  • ????????f[i]?=?-1;??
  • ??
  • ????cout<<fun(4);??
  • ????return?0;??
  • }??

  • 由于計(jì)算的時(shí)候只需要前兩個(gè)數(shù)即可,所以代碼還可以繼續(xù)優(yōu)化。但是對(duì)于上述的備忘錄方法貌似不能繼續(xù)進(jìn)行空間優(yōu)化了(不知道對(duì)否,如果理解的不對(duì)請(qǐng)不吝賜教~)。

    但是對(duì)于下面的方法(就稱為遍歷方法吧),還是可以繼續(xù)優(yōu)化的。 ?自底向上的動(dòng)態(tài)規(guī)劃

    [cpp]?view plaincopy
  • #include?<iostream>??
  • using?namespace?std;??
  • ??
  • const?int?N?=?100;??
  • int?f[N];??
  • ??
  • int?main()??
  • {??
  • ??????
  • ????int?n;??
  • ????cin>>n;??
  • ??
  • ????for?(int?i=0;?i<=n;?i++)??
  • ????{??
  • ????????if(i==0)??
  • ????????????f[i]?=?0;??
  • ????????else?if(i==1)??
  • ????????????f[i]?=?1;??
  • ????????else??
  • ????????????f[i]?=?f[i-1]?+?f[i-2];??
  • ????}??
  • ??
  • ????cout<<f[n];??
  • ??
  • ????return?0;??
  • }??
  • 斐波那契數(shù)(動(dòng)態(tài)規(guī)劃)通過把所計(jì)算的值存儲(chǔ)在遞歸過程的外部數(shù)組中,明確地避免重復(fù)計(jì)算。這一程序計(jì)算的時(shí)間與N成正比。int F(int i){if(knownF[i] != unknown)return knownF[i];if(i == 0) t = 0;if(i == 1) t = 1;if(i > 1) t = F(i - 1) + F(i - 2);return knownF[i] = t;}
    自頂向下的動(dòng)態(tài)規(guī)劃


    由于計(jì)算的時(shí)候只用了前兩個(gè)數(shù),所以沒有必要使用數(shù)組。

    [cpp]?view plaincopy
  • #include?<iostream>??
  • using?namespace?std;??
  • ??
  • int?main()??
  • {??
  • ????int?n;??
  • ????cin>>n;??
  • ??
  • ????int?temp1,?temp2,?temp;??
  • ????for?(int?i=0;?i<=n;?i++)??
  • ????{??
  • ????????if(i==0)??
  • ????????????temp1?=?0;??
  • ????????else?if(i==1)??
  • ????????????temp2?=?1;??
  • ????????else??
  • ????????{??
  • ????????????temp?=?temp1?+?temp2;??
  • ????????????temp1?=?temp2;??
  • ????????????temp2?=?temp;??
  • ??????????????
  • ????????}??
  • ????}??
  • ??
  • ????cout<<temp;??
  • ??
  • ????return?0;??
  • }??

  • 總結(jié):從代碼中可以看出來,遍歷方法實(shí)際上是一種自底向上的方法,而備忘錄方法是一種自頂向下的方法,也許正由于這個(gè)原因造成了備忘錄方法無法進(jìn)行空間優(yōu)化。(待證)

    總結(jié)

    以上是生活随笔為你收集整理的斐波那契数列 递推 递归 备忘录 动态规划的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。