动态规划思想分析——经典题目

动态规划思想是算法设计中很重要的一个思想,所谓动态规划就是“边走边看”,前面的知道了,后面的根据前面的也就可以推出来了。和分治算法相似又不同,相同的是都需要去寻找最优子结构,重复子问题,边界条件。不同的是动态规划算法存储前面算得的每一个结果,后面的结果由前面的结果推倒得出。而分治则是分而治之,把问题分开解决,再合并。不存在前后两个状态之间的转换关系(想想快速排序和LCS即可想到),快速排序法就是分治的一个典型应用。通俗来说,动态规划本质上来说还是规划,是不断进行决策的问题,一般用于求解最(优)值;而分治是一种处理复杂问题的方法,不仅仅只用于解决最值问题。

先来看动态规划,这是五大算法思想中最重要也是很常用的一个,在以后的blog中,我会慢慢地更新其他四种算法思想的分析。

动态规划有以下几个重要方面的组成:

1.最优子结构:如果问题的最优解包含的子问题的解也是最优的,就称该问题具有最优子结构

2.重叠子问题你找到的最优子结构我们要将其转化为重叠子问题,用相同的方法循环求解

3.状态转换方程:你找到的每一个子问题都可以认为是一个状态下的规划问题,而状态与状态之间你需要找到关联方程,这样我们才能从最简单的状态循环求解出所需要求解的较复杂的状态

4.边界条件:即子问题的初值,你必须给出规模较小的一些子问题的初值来开启循环,否则无法循环求解

4.子问题独立:独立问题,主要是子问题各对象的独立,不要发生一个子问题在操作时修改了另一个子问题中的变量的情况,具体可见我的递归模式的思考一文

5.无后效性:某个阶段状态一旦确定就不再受后续状态决策的影响。即某状态之后的过程不会影响以前的状态,只与当前状态有关

其中问题具有最优子结构可以分解为重复子问题无后效性这是想使用DP的问题所必须具备的性质


----------------------------------我是分割线~---------------------------------


本文先介绍一类动态规划的常见问题——串与序列(串必须连续,序列可以

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值