国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

Fibonacci數(shù)列算法的幾種實現(xiàn)方式與比較

2019-11-06 06:31:56
字體:
供稿:網(wǎng)友

斐波那契數(shù)列1,1,2,3,5,8…,對于該數(shù)列的求解又如下幾種方式。

version1

//version1int Fibonacci(int n,int* f){  f[0]=1;  f[1]=1;  for(int i=2;i<n;i++)     f[n]=f[n-1]+f[n-2];  return f[n-1];  }
分析:輸入?yún)?shù)是一個存儲斐波那契數(shù)列的數(shù)組,返回第n個數(shù)的值。該算法運用動態(tài)規(guī)劃,將所有的斐波那契數(shù)計算并存儲在數(shù)組中,使得各個數(shù)不需要重復(fù)計算。時間復(fù)雜度為O(n),空間復(fù)雜度為數(shù)組n的大小。

version2

//version2int Fibonacci(int n){if(n==1)   return 1;if(n==2)   int f_twoback=1;   int f_oneback=1;   int f;   for(int i=2;i<n;i++)   {         f=f_twoback+f_oneback;         twoback=f_oneback;         f_oneback=f;    }    return f; }
分析:有時候我們只需要斐波那契數(shù)列的其中某個位置的數(shù),并不需要所有的數(shù)列,所以我們可以用2個變量來存儲其兩個加數(shù),從而并不需要數(shù)組的存儲,并能夠節(jié)省空間。算法的時間復(fù)雜度還是同version1.

version3

//version3 int fibonacci(int n){ if(n==1) return 1; if(n==2) return 2; return fibonacci(n-1)+fibonacci(n-2);}
分析:該算法是遞歸版本,雖然結(jié)構(gòu)簡單,但是復(fù)雜度很高,效率低下。

version4

//version4memorized_fibonacci_recurs(int* results,int n){ if(results[n]!=-1) return results[n]; if(n==1) val=1; else if(n==2) val=1; else { val=memorized_fibonacci_recurs(results,n-2); val+=memorized_fibonacci_recurs(results,n-1); } results[n]=val; return val;}int memorized_fibonacci(int n){ return memorized_fibonacci_recurs(results.n);}
分析:該方法稱為備查技術(shù),試圖通過使用動態(tài)規(guī)劃的借本思想來解除遞歸算法中潛在的低效率。備查并不排除將問題劃分為子問題時尋找一種好方法的需求,但當(dāng)問題一旦實現(xiàn)了劃分,就讓我們編寫一個遞歸的算法,首先添加一張表,該表以遞歸函數(shù)的可能輸入作為索引,首先檢查函數(shù)所需要的輸入是否已經(jīng)存放在表中,如果已經(jīng)在表中,直接返回,不必重新計算,否則,遞歸調(diào)用函數(shù)。注意,該算法中val=memorized_fibonacci_recurs(results.n-2)必須在前,如果n-1在前,會出現(xiàn)復(fù)雜度上升的情況。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 比如县| 达拉特旗| 资兴市| 色达县| 筠连县| 仙游县| 盘山县| 陈巴尔虎旗| 仁化县| 泸水县| 盐边县| 广西| 闽清县| 庆安县| 桃园市| 固原市| 吉林市| 扬中市| 谢通门县| 通州区| 龙江县| 彰武县| 新竹市| 霍邱县| 景东| 古丈县| 陆川县| 定远县| 称多县| 平潭县| 湄潭县| 沂源县| 白城市| 东城区| 桂林市| 勃利县| 图木舒克市| 兴和县| 边坝县| 宿州市| 婺源县|