亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言求Fibonacci斐波那契數列通項問題的解法總結

2020-01-26 14:34:08
字體:
來源:轉載
供稿:網友

一:遞歸實現
   使用公式f[n]=f[n-1]+f[n-2],依次遞歸計算,遞歸結束條件是f[1]=1,f[2]=1。

二:數組實現
   空間復雜度和時間復雜度都是0(n),效率一般,比遞歸來得快。

三:vector<int>實現
   時間復雜度是0(n),時間復雜度是0(1),就是不知道vector的效率高不高,當然vector有自己的屬性會占用資源。

四:queue<int>實現
   當然隊列比數組更適合實現斐波那契數列,時間復雜度和空間復雜度和vector<int>一樣,但隊列太適合這里了,
   f(n)=f(n-1)+f(n-2),f(n)只和f(n-1)和f(n-2)有關,f(n)入隊列后,f(n-2)就可以出隊列了。

五:迭代實現
   迭代實現是最高效的,時間復雜度是0(n),空間復雜度是0(1)。

六:公式實現
百度的時候,發現原來斐波那契數列有公式的,所以可以使用公式來計算的。

由于double類型的精度還不夠,所以程序算出來的結果會有誤差,如果把公式展開計算,得出的結果就是正確的。

完整的實現代碼如下:

#include "iostream" #include "queue" #include "cmath" using namespace std;  int fib1(int index)   //遞歸實現 {   if(index<1)   {     return -1;   }   if(index==1 || index==2)     return 1;   return fib1(index-1)+fib1(index-2); } int fib2(int index)   //數組實現 {   if(index<1)   {     return -1;   }   if(index<3)   {     return 1;   }   int *a=new int[index];   a[0]=a[1]=1;   for(int i=2;i<index;i++)     a[i]=a[i-1]+a[i-2];   int m=a[index-1];   delete a;     //釋放內存空間   return m; }  int fib3(int index)      //借用vector<int>實現 {   if(index<1)   {     return -1;   }    vector<int> a(2,1);   //創建一個含有2個元素都為1的向量   a.reserve(3);   for(int i=2;i<index;i++)   {     a.insert(a.begin(),a.at(0)+a.at(1));     a.pop_back();   }   return a.at(0); }   int fib4(int index)    //隊列實現 {   if(index<1)   {     return -1;   }   queue<int>q;   q.push(1);   q.push(1);   for(int i=2;i<index;i++)   {     q.push(q.front()+q.back());     q.pop();   }   return q.back(); } int fib5(int n)     //迭代實現 {   int i,a=1,b=1,c=1;   if(n<1)   {     return -1;   }   for(i=2;i<n;i++)   {     c=a+b;   //輾轉相加法(類似于求最大公約數的輾轉相除法)     a=b;     b=c;   }   return c; } int fib6(int n) {   double gh5=sqrt((double)5);   return (pow((1+gh5),n)-pow((1-gh5),n))/(pow((double)2,n)*gh5); }   int main(void) {   printf("%d/n",fib3(6));   system("pause");   return 0; } 

七:二分矩陣方法

201663185151250.gif (312×428)

如上圖,Fibonacci 數列中任何一項可以用矩陣冪算出,而n次冪是可以在logn的時間內算出的。
下面貼出代碼:

void multiply(int c[2][2],int a[2][2],int b[2][2],int mod) {   int tmp[4];   tmp[0]=a[0][0]*b[0][0]+a[0][1]*b[1][0];   tmp[1]=a[0][0]*b[0][1]+a[0][1]*b[1][1];   tmp[2]=a[1][0]*b[0][0]+a[1][1]*b[1][0];   tmp[3]=a[1][0]*b[0][1]+a[1][1]*b[1][1];   c[0][0]=tmp[0]%mod;   c[0][1]=tmp[1]%mod;   c[1][0]=tmp[2]%mod;   c[1][1]=tmp[3]%mod; }//計算矩陣乘法,c=a*b  int fibonacci(int n,int mod)//mod表示數字太大時需要模的數 {   if(n==0)return 0;   else if(n<=2)return 1;//這里表示第0項為0,第1,2項為1    int a[2][2]={{1,1},{1,0}};   int result[2][2]={{1,0},{0,1}};//初始化為單位矩陣   int s;   n-=2;   while(n>0)   {     if(n%2 == 1)       multiply(result,result,a,mod);     multiply(a,a,a,mod);     n /= 2;   }//二分法求矩陣冪   s=(result[0][0]+result[0][1])%mod;//結果   return s; } 

附帶的再貼上二分法計算a的n次方函數。

int pow(int a,int n) {   int ans=1;   while(n)   {     if(n&1)       ans*=a;     a*=a;     n>>=1;   }   return ans; } 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区免费在线| 亚洲精品久久久久中文字幕二区| 国内精品久久久久久影视8| 亚洲精品视频中文字幕| 欧美激情在线有限公司| 日韩欧美黄色动漫| 另类图片亚洲另类| 精品视频久久久久久| 成人国产精品色哟哟| 中文字幕在线观看日韩| 亚洲成**性毛茸茸| 欧美激情亚洲视频| 久久久噜久噜久久综合| 国产精品久久久久久久久久久久久久| 国产日韩视频在线观看| 91在线观看免费网站| 一区二区av在线| 精品久久香蕉国产线看观看gif| 中文在线资源观看视频网站免费不卡| 最近2019好看的中文字幕免费| 欧美激情精品久久久| 国外成人在线直播| 大量国产精品视频| 日韩av在线高清| 国产精品视频一区二区高潮| 国产一区二区黑人欧美xxxx| 国产精品直播网红| 日韩精品在线免费播放| 亚洲精品一区二三区不卡| 日本不卡高字幕在线2019| 欧美性猛交丰臀xxxxx网站| 精品丝袜一区二区三区| 亚洲国产中文字幕在线观看| 国产精品久久久久高潮| 精品性高朝久久久久久久| 欧美日韩中文字幕综合视频| 2025国产精品视频| 18性欧美xxxⅹ性满足| 韩国三级电影久久久久久| 久久97精品久久久久久久不卡| 亚洲国产精品久久久久久| 懂色av一区二区三区| 91在线视频九色| 亚洲欧美一区二区三区在线| 亚洲美女av在线播放| 国产精品老女人精品视频| 国产又爽又黄的激情精品视频| 国产成人亚洲综合| 国产精品午夜一区二区欲梦| 一区二区三区四区在线观看视频| 美女精品视频一区| 亚洲xxxxx电影| 欧美激情综合亚洲一二区| 中文国产亚洲喷潮| 欧美日韩国产综合视频在线观看中文| 日韩高清av一区二区三区| 亚洲国产精品久久精品怡红院| 国产成+人+综合+亚洲欧美丁香花| 亚洲第一免费网站| 欧美性猛交xxxxx水多| 欧美激情日韩图片| 日韩在线播放视频| 亚洲欧美变态国产另类| 日韩免费在线视频| 国产精品爽黄69天堂a| 中文字幕久热精品在线视频| 日韩成人激情视频| 久久久免费电影| 中文字幕亚洲图片| 亚洲精品美女在线观看| www.亚洲天堂| 最近中文字幕mv在线一区二区三区四区| 欧美激情性做爰免费视频| 欧美成人国产va精品日本一级| 国产精品jizz在线观看麻豆| 欧美另类交人妖| 久久中国妇女中文字幕| 国产深夜精品福利| 国产一区二中文字幕在线看| 国产香蕉97碰碰久久人人| 欧美一级电影久久| 亚洲欧美成人在线| 最近的2019中文字幕免费一页| 97在线免费观看| 中文字幕视频一区二区在线有码| 国产成+人+综合+亚洲欧洲| 亚洲精品福利在线| 成人福利视频在线观看| 欧美成人精品激情在线观看| 伊人久久大香线蕉av一区二区| 欧美日韩aaaa| 欧美成人午夜激情| 欧美国产日韩视频| 91国产视频在线| 亚洲男人天堂网站| 国产精品jvid在线观看蜜臀| 欧美一级视频一区二区| 精品国产福利视频| 一本色道久久综合狠狠躁篇怎么玩| 欧美www视频在线观看| 国产精品一区二区3区| 久久九九免费视频| 日韩av在线影院| 日韩欧美国产黄色| 亚洲高清福利视频| 性欧美xxxx视频在线观看| 欧美多人爱爱视频网站| 日韩美女视频免费在线观看| 欧美激情国产精品| 91亚洲精品在线| 欧美成人激情视频免费观看| 国产色婷婷国产综合在线理论片a| 国产精品久久999| 在线观看日韩欧美| 中文字幕精品av| 日韩有码在线观看| 日韩中文在线中文网三级| 国产一区二区三区视频在线观看| 日韩欧美在线免费观看| 欧美日韩国产综合视频在线观看中文| 91视频国产高清| 欧美日韩免费一区| 亚洲香蕉成人av网站在线观看| 欧美视频裸体精品| 国产精品热视频| 97在线看福利| 欧美精品在线播放| 亚洲成年人在线播放| 日韩欧美在线视频| 亚洲人成在线观| 国产精品69精品一区二区三区| 成人欧美一区二区三区黑人孕妇| 久久久久久网站| 韩国美女主播一区| 国产精品夫妻激情| 国产精品白丝jk喷水视频一区| 日韩精品一区二区三区第95| 国产精品久久网| 成人亚洲综合色就1024| 欧美激情在线观看视频| 亚洲国产精品中文| 亚洲图片制服诱惑| 久久久99久久精品女同性| 国产精品jizz在线观看麻豆| 国产精品啪视频| 国a精品视频大全| 97久久精品人人澡人人爽缅北| 日产日韩在线亚洲欧美| 欧美日韩一区二区三区在线免费观看| 久久久久九九九九| 国产精品永久免费观看| 亚洲夜晚福利在线观看| 日韩大片免费观看视频播放| 久久精品国产亚洲精品| 欧美激情精品久久久久久黑人| 亚洲 日韩 国产第一| 久久男人av资源网站| 日韩电影免费观看中文字幕| 精品综合久久久久久97| 国产精品成人国产乱一区| 亚洲国产毛片完整版| 国产精品亚洲自拍| 成人免费看黄网站| 国内偷自视频区视频综合|