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

动态规划基本概念

动态规划是一种解决复杂问题的优化技术,通过将问题分解为子问题并存储子问题的解来避免重复计算。适用于具有重叠子问题和最优子结构性质的问题。

动态规划实现步骤

问题分析 明确问题的状态定义,确定状态转移方程,识别边界条件。例如在斐波那契数列中,状态定义为dp[i]表示第i项的值,状态转移方程为dp[i] = dp[i-1] + dp[i-2]

初始化DP表 根据问题需求创建一维或二维数组存储中间结果。初始化边界条件,如斐波那契数列中dp[0] = 0dp[1] = 1

填充DP表 按顺序或逆序填充DP表,确保在计算当前状态时所需的前驱状态已被计算。例如斐波那契数列从i=2开始迭代至目标值。

提取结果 DP表的最后一个元素或特定位置通常为最终解。例如斐波那契数列返回dp[n]

经典问题示例

斐波那契数列

cpp 复制代码
int fib(int n) {
    if (n <= 1) return n;
    int dp[n+1];
    dp[0] = 0; dp[1] = 1;
    for (int i = 2; i <= n; ++i) {
        dp[i] = dp[i-1] + dp[i-2];
    }
    return dp[n];
}

最长公共子序列(LCS)

cpp 复制代码
int lcs(string X, string Y) {
    int m = X.length(), n = Y.length();
    int dp[m+1][n+1];
    for (int i = 0; i <= m; ++i) {
        for (int j = 0; j <= n; ++j) {
            if (i == 0 || j == 0) dp[i][j] = 0;
            else if (X[i-1] == Y[j-1]) dp[i][j] = dp[i-1][j-1] + 1;
            else dp[i][j] = max(dp[i-1][j], dp[i][j-1]);
        }
    }
    return dp[m][n];
}

优化技巧

空间优化 对于某些问题,可通过滚动数组或压缩状态减少空间复杂度。例如斐波那契数列只需保存前两个状态:

cpp 复制代码
int fib(int n) {
    if (n <= 1) return n;
    int prev = 0, curr = 1;
    for (int i = 2; i <= n; ++i) {
        int next = prev + curr;
        prev = curr;
        curr = next;
    }
    return curr;
}

备忘录法 自顶向下递归配合缓存已计算结果,避免重复计算:

cpp 复制代码
unordered_map<int, int> memo;
int fib(int n) {
    if (n <= 1) return n;
    if (memo.find(n) != memo.end()) return memo[n];
    return memo[n] = fib(n-1) + fib(n-2);
}

常见应用场景

  • 背包问题(01背包、完全背包)
  • 矩阵链乘法
  • 最短路径问题(Floyd-Warshall算法)
  • 字符串编辑距离
  • 股票买卖问题

通过系统性地分解问题、存储中间结果和构建状态转移方程,动态规划能高效解决许多优化问题。

相关推荐
橘色的喵2 小时前
现代C++嵌入式消息总线的回调优化: 从 std::function 到零开销分发
c++·function
yblackd2 小时前
UnrealEngine Win风格 窗口选择打开文件
c++·ue5·虚幻
橘色的喵2 小时前
C++17 vs C 编译产物体积:工业嵌入式场景的实测与分析
c语言·c++·c++17
望舒5132 小时前
代码随想录day32,动态规划part1
java·算法·leetcode·动态规划
楠秋9202 小时前
代码随想录算法训练营第三十二天| 509. 斐波那契数 、 70. 爬楼梯 、746. 使用最小花费爬楼梯
数据结构·算法·leetcode·动态规划
闻缺陷则喜何志丹2 小时前
【进制】P2320 [HNOI2006] 鬼谷子的钱袋|普及+
c++·算法·进制
月挽清风3 小时前
代码随想录第32天:动态规划
算法·动态规划
2501_901147833 小时前
硬币找零问题的动态规划解法与实现思考笔记
笔记·算法·动态规划
Pluchon3 小时前
硅基计划4.0 算法 图的存储&图的深度广度搜索&最小生成树&单源多源最短路径
java·算法·贪心算法·深度优先·动态规划·广度优先·图搜索算法