大家是怎麼實現斐波那契列數的1,1,2,3,5,8...f(n)=f(n-1) + f(n-2) 方法一: function f(n){ if(n == 1 || n == 0){ return 1; } return f(n-1) + f(n-2); } index.html 再給兩種解法,對比一 ...
大家是怎麼實現斐波那契列數的
1,1,2,3,5,8...
f(n)=f(n-1) + f(n-2)
方法一:
function f(n){ if(n == 1 || n == 0){ return 1; } return f(n-1) + f(n-2); }index.html
再給兩種解法,對比一下
方法二:
function f(n) { var arr = []; var value = null; function _f(n) { if (n == 1 || n == 0) { return 1; } if (arr[n]) return arr[n]; value = _f(n - 1) + _f(n - 2); arr[n] = value; return value; } return _f(n); }方法二
還有一種更簡單的用的是數組存儲
方法三:
function fn(n) { var dp = new Array(n + 1); dp[0] = dp[1] = 1; for (let i = 2, length = dp.length; i < length; i++) { dp[i] = dp[i - 1] + dp[i - 2]; } return dp[n]; }方法三