【算法 - 动态规划】从零开始学动态规划!(总纲)

本文介绍了动态规划的基本概念,如最优子结构、状态转移方程和存储中间结果,对比了暴力递归的不足,并阐述了动态规划的求解步骤,包括定义状态、状态转移方程和使用自底上/自顶下的方法。后续将探讨如何从暴力递归过渡到动态规划的实际应用。
摘要由CSDN通过智能技术生成

动态规划

动态规划(Dynamic Programming,DP)是一种优化问题求解方法,通常用于解决具有 重叠子问题最优子结构 性质的问题。它的基本思想是将原问题分解成更小的子问题,通过求解和保存这些子问题的解,避免重复计算,从而提高算法的效率。

基本概念:

  1. 最优子结构:

    • 最优子结构是指问题的最优解可以通过 子问题的最优解递归 构建而成。在动态规划中,原问题被分解为更小的子问题,每个子问题都有自己的最优解。通过合并这些最优解,我们可以得到整体问题的最优解。
  2. 重叠子问题:

    • 动态规划问题会涉及到重叠子问题,即在解问题的过程中会多次遇到 相同的子问题。为了避免重复计算,动态规划使用记忆化或者其他方法来保存子问题的解。
  3. 状态转移方程:

    • 状态转移方程是问题建模的关键,它描述了问题的 当前状态 和如何从之前的状态
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

强连通子图

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值