动态规划

一道需要采用动态规划解决的题的特点有哪些?

面试时面试官不会明说,请采用动态规划算法解决这道题,所以我们首先应该判断一道题是否需要采用动态规划。
1.计数型:
多少种方式走到右下角
多少种方法选出k个数使得是Sum

2.求最值:
从路径的最大和
最长
3.求存在性:
取石子游戏,先手是否必胜
能不能选出k个数使得和是Sum

动态规划与分治方法类似,都是通过组合子问题的解来来求解原问题的。
再来了解一下什么是分治方法,以及这两者之间的差别,分治方法将问题划分为互不相交的子问题,递归的求解子问题,再将它们的解组合起来,求出原问题的解。而动态规划与之相反,动态规划应用与子问题重叠的情况,即不同的子问题具有公共的子子问题(子问题的求解是递归进行的,将其划分为更小的子子问题)。在这种情况下,分治方法会做许多不必要的工作,他会反复求解那些公共子子问题。而动态规划对于每一个子子问题只求解一次,将其解保存在一个表格里面,从而无需每次求解一个子子问题时都重新计算,避免了不必要的计算工作

例题讲解:硬币

有足够多数目的硬币,面值2、5、7 元。买一本书27元,如何用最少的硬币组合正好付清?
这是一道求最大最小值动态规划。
所有的动态规划题,都会采用四个步骤去做:
一. 确定状态
解动态规划时一般需要开一个数组,数组中的每个元素f[i]代表,就是状态。类似数学题中函数的未知量x,y,z
数组即状态
确定状态需要两步:①. 最后一步。 ②.子问题
①. 最后一步: 这道题中的最后一步:一定有一枚最后的硬币:ak
在这里插入图片描述
除掉这枚硬币后,前面硬币的面值加起来是27 - ak
在这里插入图片描述
②. 子问题:
最少用多少枚硬币可以拼出27 - ak
问题基本没变,只是规模变小,参数变小了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值