简单记录N个动态规划的例子
2017-06-18 22:21
357 查看
通过最近对于一些算法题的思考,越来越发现动态规划方法的在时间上高效性,往往该问题可以轻松的找到暴力破解的方法,其时间复杂度却不尽人意。下面来看看几个常见的动态规划思路的经典问题
例一.有一段楼梯有10级台阶,规定每一步只能跨一级或两级,要登上第10级台阶有几种不同的走法?(腾讯电面题之一)
其状态转移方程为:
f(n):表示n阶楼梯有多少种走法
f(n)=f(n−1)+f(n−2)
f(1)=1,f(2)=2
例二:01背包问题
有n个重量和价值分别为vector weight, vector value的物品;背包最大负重为W,求能用背包装下的物品的最大价值?
输入:n =4
weight=2, 1, 3, 2
value =3, 2, 4, 2
W=5
输出=7
dp[i][j]表示前i号物品中能选出重量在j之内的最大价值
dp[i][j]=max(dp[i−1][j],dp[i−1][j−w[i]]+v[i]);
例三:最大连续子序列和
如给定数组[-2,1,-3,4,-1,2,1,-5,4]
连续的子数组为[4,-1,2,1]有最大和6
f(j+1)为以下标j结尾的连续子序列和的最大值
f(j+1)=max(f(j)+A[j],A[j])
target=maxf[j]
思考:最大连续子序列乘积
如给定数组[-2,1,-3,4,-1,2,1,-5,4]
连续的子数组为[4,-1,2,1]有最大和6
f(j+1)为以下标j结尾的连续子序列最大乘积值(1)
状态转移方程如何表示呢:
这里我们知道A[j]可能为正数(或0)或负数,那么当A[j]为正数,期望前j个乘积为正数,若为负数,则期望前面的为负数。故我们需定义两个函数来确定我们的状态转移方程:
fmax(j+1)=max(max(fmax(j)∗A[j],A[j]),fmin(j)∗A[j])
fmin(j+1)=min(min(fmin(j)∗A[j],A[j]),fmax(j)∗A[j])(2)
1.通过以上动态问题问题的分析,可以看出最重要的是定义好相应的问题,然后写出状态转移方程,往往这也是整个问题求解最能考察你分析能力的过程。能够用动态规划求解的问题有两类性质:
a.重叠子问题
采用递推方式,比如上例要求出10阶楼梯走法,那么最后一步是踏一步上来或者踏2步上来,最后转化为相应的子问题,子问题深入求解就包含了重叠的子问题,所以自顶向下的实现并不高效,常采用备忘录方式保存子问题的最优解,自底向上更高效。
b.最优子结构:
往往子问题的最优解可以推出原问题的最优解
例一.有一段楼梯有10级台阶,规定每一步只能跨一级或两级,要登上第10级台阶有几种不同的走法?(腾讯电面题之一)
其状态转移方程为:
f(n):表示n阶楼梯有多少种走法
f(n)=f(n−1)+f(n−2)
f(1)=1,f(2)=2
例二:01背包问题
有n个重量和价值分别为vector weight, vector value的物品;背包最大负重为W,求能用背包装下的物品的最大价值?
输入:n =4
weight=2, 1, 3, 2
value =3, 2, 4, 2
W=5
输出=7
dp[i][j]表示前i号物品中能选出重量在j之内的最大价值
dp[i][j]=max(dp[i−1][j],dp[i−1][j−w[i]]+v[i]);
例三:最大连续子序列和
如给定数组[-2,1,-3,4,-1,2,1,-5,4]
连续的子数组为[4,-1,2,1]有最大和6
f(j+1)为以下标j结尾的连续子序列和的最大值
f(j+1)=max(f(j)+A[j],A[j])
target=maxf[j]
思考:最大连续子序列乘积
如给定数组[-2,1,-3,4,-1,2,1,-5,4]
连续的子数组为[4,-1,2,1]有最大和6
f(j+1)为以下标j结尾的连续子序列最大乘积值(1)
状态转移方程如何表示呢:
这里我们知道A[j]可能为正数(或0)或负数,那么当A[j]为正数,期望前j个乘积为正数,若为负数,则期望前面的为负数。故我们需定义两个函数来确定我们的状态转移方程:
fmax(j+1)=max(max(fmax(j)∗A[j],A[j]),fmin(j)∗A[j])
fmin(j+1)=min(min(fmin(j)∗A[j],A[j]),fmax(j)∗A[j])(2)
1.通过以上动态问题问题的分析,可以看出最重要的是定义好相应的问题,然后写出状态转移方程,往往这也是整个问题求解最能考察你分析能力的过程。能够用动态规划求解的问题有两类性质:
a.重叠子问题
采用递推方式,比如上例要求出10阶楼梯走法,那么最后一步是踏一步上来或者踏2步上来,最后转化为相应的子问题,子问题深入求解就包含了重叠的子问题,所以自顶向下的实现并不高效,常采用备忘录方式保存子问题的最优解,自底向上更高效。
b.最优子结构:
往往子问题的最优解可以推出原问题的最优解
相关文章推荐
- 动态规划简单例子(数塔问题)java
- 动态规划简单例子--象棋步骤
- 用jquery仿google动态补全简单例子
- Android 基础教程之---动态更改屏幕方向的简单例子(LANDSCAPE与PORTRAIT)!
- CUGB 1009 DP简单动态规划,此题一开始就结了很久,WA了9次对于刚开始学DP的我打击很大,最后发现原来是方法弄错了,题意没完全弄懂!看了大牛的文章才知道,差距啊!还得好好努力。
- Java动态编译一个简单的例子(我转载的,但是经过修定,可以在Eclipse下运行)
- 动态规划-------一个简单爬梯子问题
- 动态调用一个类的简单例子(java反射)
- struts中动态表单(DynaActionForm)的使用(超简单例子)
- oracle中某列连续相同值的记录数统计(一个简单的例子)
- 使用servlet开发动态wap的一个简单例子
- 一个简单的例子演示:模仿微博里面的通过浏览器的滚动条来动态加载数据
- 利用反射动态加载插件的简单例子[xgluxv]
- oracle中某列连续相同值的记录数统计(一个简单的例子)
- Android 基础教程之---动态更改屏幕方向的简单例子(LANDSCAPE与PORTRAIT)!
- CUGB 1050 题解动态规划简单题,这是我学会动态规划后做的第三道题比起前两道明显要顺手的多!秩序套用一下代码末班就行了。
- pku1157-------LITTLE SHOP OF FLOWERS(简单动态规划题:摆放鲜花使审美价值达到最高)
- 动态规划;漂亮打印问题;时间复杂度O(n方); 思考方法记录在内;
- 一道简单的但是经典的动态规划题目
- 简单动态规划——电路布线