一道需要采用动态规划解决的题的特点有哪些?
面试时面试官不会明说,请采用动态规划算法解决这道题,所以我们首先应该判断一道题是否需要采用动态规划。
1.计数型:
有多少种方式走到右下角
有多少种方法选出k个数使得和是Sum
…
2.求最值:
从路径的最大和
最长…
3.求存在性:
取石子游戏,先手是否必胜
能不能选出k个数使得和是Sum
动态规划与分治方法类似,都是通过组合子问题的解来来求解原问题的。
再来了解一下什么是分治方法,以及这两者之间的差别,分治方法将问题划分为互不相交的子问题,递归的求解子问题,再将它们的解组合起来,求出原问题的解。而动态规划与之相反,动态规划应用与子问题重叠的情况,即不同的子问题具有公共的子子问题(子问题的求解是递归进行的,将其划分为更小的子子问题)。在这种情况下,分治方法会做许多不必要的工作,他会反复求解那些公共子子问题。而动态规划对于每一个子子问题只求解一次,将其解保存在一个表格里面,从而无需每次求解一个子子问题时都重新计算,避免了不必要的计算工作。
例题讲解:硬币
有足够多数目的硬币,面值2、5、7 元。买一本书27元,如何用最少的硬币组合正好付清?
这是一道求最大最小值动态规划。
所有的动态规划题,都会采用四个步骤去做:
一. 确定状态
解动态规划时一般需要开一个数组,数组中的每个元素f[i]代表,就是状态。类似数学题中函数的未知量x,y,z
数组即状态
确定状态需要两步:①. 最后一步。 ②.子问题
①. 最后一步: 这道题中的最后一步:一定有一枚最后的硬币:ak
除掉这枚硬币后,前面硬币的面值加起来是27 - ak
②. 子问题:
最少用多少枚硬币可以拼出27 - ak
问题基本没变,只是规模变小,参数变小了。