简单的0/1背包问题,用动态规划即可简单求解。
以下一段话摘自Slyar.
==========================================================
Slyar:标准的01背包,动态转移方程如下。其中dp[i,j]表示的是前i个物品装入容量为j的背包里所能产生的最大价值,w[i]是第i个物品的重量,d[i]是第i个物品的价值。如果某物品超过背包容量,则该物品一定不放入背包,问题变为剩余i-1个物品装入容量为j的背包所能产生的最大价值;否则该物品装入背包,问题变为剩余i-1个物品装入容量为j-w[i]的背包所能产生的最大价值加上物品i的价值d[i]...恩,多清晰...
==========================================================
先上一个用二维数组求解的代码,这个代码比较容易理解。为了求深理解,可以在纸上自己试着计算下这个二维数组dp。
由于OJ上memory所限,上面代码提交上去会MLE的。在纸上计算dp过程中,发觉dp设置成n行的二维数组实际上没有必要,因为在计算dp第i行时只用到dp第i-1行的数据,而且到了最后,前面n-1行都没用的。因此,完全可以用一维数组进行计算。但要注意,应从后住前计算dp,否则dp的数据会被新计算的值覆盖,导致不正确。
观察二重for循环,可以发觉其实还可以继续进一步优化下。最终的程序版本为:
分享到:
相关推荐
poj-1002源码,没有题解,题解看博客poj-1002源码,没有题解,题解看博客poj-1002源码,没有题解,题解看博客poj-1002源码,没有题解,题解看博客
北大POJ1015-Jury Compromise【动态规划DP】 解题报告+AC代码
POJ---1456.Supermarket测试数据及答案,题目描述:A supermarket has a set Prod of products on sale. It earns a profit px for each product x∈Prod sold by a deadline dx that is measured as an integral ...
北大POJ初级-动态规划 解题报告+AC代码
关于poj dp分类,我一直寻找dp的分类,终于找到了,也上传一下
POJ-3299解题 C++源代码 Description Adapted from Wikipedia, the free encyclopedia The humidex is a measurement used by Canadian meteorologists to reflect the combined effect of heat and humidity. It...
poj 1000 - 2000 部分题目 官方分类 poj 1000 - 2000 部分题目 官方分类
西北工业大学-c语言-POJ-题目及答案-第七季.doc
poj-2528 Mayor's posters 测试数据及答案
北大POJ2002-Squares 解题报告+AC代码
POJ-2870 Light Up + DFS(1级DFS+1级DFS) + Python - 思维导图 链接:https://blog.csdn.net/xxdragon126/article/details/122095922?spm=1001.2014.3001.5501
北大POJ3253-POJ3253-Fence Repair【STL优先队列】 解题报告+AC代码
北大POJ2525-Text Formalization【TrieTree】 解题报告+AC代码+测试数据 http://hi.csdn.net/!s/XW4FQ3
算法-炮兵阵地(POJ-1185)(包含源程序).rar