动态规划之斐波那契数列

动态规划(Dynamic Programming, DP)是一种算法策略,用于解决具有重叠子问题和最优子结构特性的问题。

问题描述

斐波那契数列是一个每一项都是前两项和的序列:0, 1, 1, 2, 3, 5, 8, 13, ...

动态规划解法

使用递归方法解决斐波那契数列问题会有很多重复计算,而动态规划通过存储中间结果来避免这种情况。

样例

计算斐波那契数列的第 n 项。

javascript 复制代码
// 动态规划求解斐波那契数列
function fibonacci(n) {
  // 创建一个数组来存储斐波那契数列的中间结果
  let fib = new Array(n + 1);

  // 初始值
  fib[0] = 0;
  fib[1] = 1;

  // 计算斐波那契数列的值
  for (let i = 2; i <= n; i++) {
    fib[i] = fib[i - 1] + fib[i - 2];
  }

  // 返回第 n 项
  return fib[n];
}

// 示例:计算斐波那契数列的第 10 项
console.log(fibonacci(10)); // 输出 55

解释

我们创建了一个数组 fib 来存储已经计算过的斐波那契数列的值。

我们从第 2 项开始,使用 fib[i - 1] + fib[i - 2] 来计算当前项,这样避免了递归中的重复计算。

最终,fib[n] 存储的就是斐波那契数列的第 n 项。

优化空间复杂度

上述解法的空间复杂度为 O(n),我们可以通过只存储前两个值来优化到 O(1)。

优化后的代码

javascript 复制代码
function fibonacciOptimized(n) {
  if (n <= 1) return n;

  let prev = 0;
  let current = 1;

  for (let i = 2; i <= n; i++) {
    let temp = current;
    current = prev + current;
    prev = temp;
  }

  return current;
}

// 示例:计算斐波那契数列的第 10 项
console.log(fibonacciOptimized(10)); // 输出 55

解释

我们使用两个变量 prev 和 current 来存储前两个斐波那契数。

在每次迭代中,我们更新这两个变量的值为新的斐波那契数。

这种方法只需要常数级别的空间。

以上就是文章全部内容了,如果喜欢这篇文章的话,还希望三连支持一下,感谢!

相关推荐
他们叫我一代大侠11 分钟前
Leetcode :模拟足球赛小组各种比分的出线状况
算法·leetcode·职场和发展
Nebula_g14 分钟前
C语言应用实例:硕鼠游戏,田忌赛马,搬桌子,活动选择(贪心算法)
c语言·开发语言·学习·算法·游戏·贪心算法·初学者
AI科技星1 小时前
张祥前统一场论动量公式P=m(C-V)误解解答
开发语言·数据结构·人工智能·经验分享·python·线性代数·算法
海琴烟Sunshine1 小时前
leetcode 345. 反转字符串中的元音字母 python
python·算法·leetcode
geobuilding1 小时前
将大规模shp白模贴图转3dtiles倾斜摄影,并可单体化拾取建筑
算法·3d·智慧城市·数据可视化·贴图
jghhh011 小时前
基于高斯伪谱法的弹道优化方法及轨迹仿真计算
算法
mm-q29152227293 小时前
【天野学院5期】 第5期易语言半内存辅助培训班,主讲游戏——手游:仙剑奇侠传4,端游:神魔大陆2
人工智能·算法·游戏
MoRanzhi12033 小时前
Python 实现:从数学模型到完整控制台版《2048》游戏
数据结构·python·算法·游戏·数学建模·矩阵·2048
2401_841495644 小时前
【数据结构】基于BF算法的树种病毒检测
java·数据结构·c++·python·算法·字符串·模式匹配
蒙奇D索大4 小时前
【算法】递归算法实战:汉诺塔问题详解与代码实现
c语言·考研·算法·面试·改行学it