什么是动态规划(DP)?(Python版)

动态规划(DP)的核心概念

动态规划是一种通过将问题分解为子问题并存储子问题解来优化计算的算法策略。适用于具有重叠子问题最优子结构性质的问题。

  • 重叠子问题:子问题在求解过程中被多次重复计算,例如斐波那契数列的递归实现。
  • 最优子结构:问题的最优解包含子问题的最优解,例如最短路径问题。

DP问题的解决步骤

  1. 定义状态

    明确问题的状态表示,通常用数组或矩阵存储子问题的解。例如,dp[i]表示第i个斐波那契数。

  2. 状态转移方程

    建立子问题之间的关系式。例如斐波那契数列的转移方程为:

    dp\[i\] = dp\[i-1\] + dp\[i-2\]

  3. 初始化与边界条件

    设置初始值以避免无限递归。例如斐波那契数列中:

    dp\[0\] = 0, \\quad dp\[1\] = 1

  4. 计算顺序

    确定填表顺序(自顶向下或自底向上)。例如斐波那契数列通常采用自底向上的迭代法。

  5. 空间优化(可选)

    根据状态转移的依赖关系压缩存储空间。例如斐波那契数列只需两个变量代替整个数组。

经典DP问题示例

背包问题

问题描述 :给定物品重量weight和价值value,在容量为W的背包中求最大价值。

  • 状态定义dp[i][j]表示前i个物品在容量j时的最大价值。
  • 状态转移

    dp\[i\]\[j\] = \\max(dp\[i-1\]\[j\], \\quad dp\[i-1\]\[j - \\text{weight}\[i\]\] + \\text{value}\[i\])

最长公共子序列(LCS)

问题描述 :求两个字符串XY的最长公共子序列长度。

  • 状态定义dp[i][j]表示X[0..i-1]Y[0..j-1]的LCS长度。
  • 状态转移

    dp\[i\]\[j\] = \\begin{cases} dp\[i-1\]\[j-1\] + 1 \& \\text{if } X\[i-1\] = Y\[j-1\], \\ \\max(dp\[i-1\]\[j\], dp\[i\]\[j-1\]) \& \\text{otherwise}. \\end{cases}

DP与分治的区别

  • 分治:子问题独立无重叠(如归并排序),通常用递归实现。
  • DP:子问题重叠,通过记忆化或填表避免重复计算。

代码示例(斐波那契数列)

python 复制代码
def fibonacci(n):
    if n <= 1:
        return n
    dp = [0] * (n + 1)
    dp[1] = 1
    for i in range(2, n + 1):
        dp[i] = dp[i - 1] + dp[i - 2]
    return dp[n]

通过理解核心思想并练习经典问题,可以逐步掌握动态规划的解题模式。

相关推荐
2301_8038756110 小时前
PHP 中处理会话数组时的类型错误解析与修复指南
jvm·数据库·python
m0_7436239210 小时前
c++如何批量修改文件后缀名_std--filesystem--replace_extension【实战】
jvm·数据库·python
2501_9142459311 小时前
CSS如何处理CSS变量作用域冲突_利用特定类名重写变量值
jvm·数据库·python
菜鸟学Python11 小时前
Python生态在悄悄改变:FastAPI全面反超,Django和Flask还行吗?
开发语言·python·django·flask·fastapi
<-->11 小时前
Megatron(全称 Megatron-LM,由 NVIDIA 开发)和 DeepSpeed(由 Microsoft 开发)
人工智能·pytorch·python·深度学习·transformer
测试199811 小时前
2026最新软件测试面试八股文【附文档】
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
故事和你9112 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
maqr_11012 小时前
MySQL数据库迁移到云端如何保障安全_数据加密与SSL连接配置
jvm·数据库·python
u01091476012 小时前
MySQL如何限制触发器递归调用的深度_防止触发器死循环方法
jvm·数据库·python
weixin_3812881812 小时前
MySQL中如何使用HEX函数转换十六进制_MySQL进制转换函数
jvm·数据库·python