1. 使用动态规划递推法
2. 时间复杂度为O(n)
3. 不使用递归, 递归的时间复杂度为O(2^n) 指数级复杂度
function fibonacci(n) {
if (n < 1) throw new Error('n is not greater than 0');
if (n == 1 || n == 2) return 1;
let a = new Array(n);
a[0] = 1;
a[1] = 1;
for (let i = 2; i < n; i++) {
a[i] = a[i - 1] + a[i - 2];
}
return a[n - 1];
}



京公网安备 11010502036488号