劍指offer——斐波那契數列
經典題目,用了兩種方法實現。第一種是迴圈,不要搞陣列浪費記憶體,三個值就行了。從i=2遍歷到i==n。
第二種是遞迴+dp,因為這題直接遞迴會費時,比如計算F(5)=F(4)+F(3),計算F(4)=F(3)+F(2),F(3)被重複計算。為了避免重複計算,開一個陣列dp用來儲存已經計算過的結果。遞迴有遞迴邊界,當n ==0就返回0,1就返回1。預先將dp全賦值-1,如果dp[n]的值不為-1,就直接返回結果。如果為-1,就計算dp[n]=F(n-1) + F(n-2),然後返回dp[n]
class Solution {
public:
int dp[40] = {-1};
int Fibonacci(int n) {
/*迴圈
f(n==0) return 0;
if(n==1) return 1;
int first = 0;
int second = 1;
int res = 0;
for(int i = 2; i <= n; ++i){
res = first + second;
first = second;
second = res;
} */
//遞迴+動態規劃
for(int i = 0; i < 40; ++i){
dp[i] = -1;
}
dp[0] = 0;
dp[1] = 1;
if(n == 0) return 0;
if(n == 1) return 1;
return F(n-1) + F(n-2);
}
int F(int n){
if(n == 0) return 0;
if(n == 1) return 1;
if(dp[n] != -1) return dp[n];
else{
dp[n] = F(n-1) + F(n-2);
return dp[n];
}
}
};
相關文章
- 劍指offer-9-斐波那契數列-javaJava
- 劍指 Offer 10- I. 斐波那契數列
- 斐波那契數列
- offer通過--9斐波那契數列-2
- 斐波那契數列(Java)Java
- 斐波那契數列詳解
- 著名的斐波那契數列
- 斐波那契數列 (C#)C#
- PHP 與斐波那契數列PHP
- 斐波那契數
- [C103] 斐波那契數列
- 力扣之斐波那契數列力扣
- 斐波那契數列js 實現JS
- 斐波那契數列Ⅳ【矩陣乘法】矩陣
- js實現斐波那契數列JS
- 斐波那契數列演算法演算法
- 第十題:斐波那契數列
- 菲波那切數列(劍指offer)---c語言C語言
- 使用Python實現斐波那契數列Python
- 演算法(1)斐波那契數列演算法
- 斐波那契數列的來源——數兔子
- 斐波那契數列數與等冪和
- LeetCode 509[斐波那契數]LeetCode
- Leedcode-斐波那契數
- 509. 斐波那契數
- 一千位斐波那契數
- JavaScript 實現:輸出斐波那契數列JavaScript
- js迭代器實現斐波那契數列JS
- 演算法一:斐波那契阿數列演算法
- 大數斐波那契數列的演算法演算法
- 斐波那契數列:7數5層魔法塔(3)
- 斐波那契數列:7數5層魔法塔(2)
- 斐波那契數列:7數5層魔法塔(5)
- 斐波那契數列:7數5層魔法塔(8)
- 斐波那契數列:7數5層魔法塔(13)
- 斐波那契數列:7數5層魔法塔(12)
- 斐波那契數列:7數5層魔法塔(10)
- 斐波那契數列:7數5層魔法塔(11)