关于动态规划【纯粹的0-1背包需要思考的问题】

目录

一、题目和代码

二、需要思考的问题


一、题目和代码

0-1背包问题:有几个物品,和一个书包,每个物品有重量和价值,书包有一个最大能装的质量,问这个书包能装的最大价值。其中,每个物品只有一个,这就是0-1背包问题

方法一:(二维数组的代码)

方法二:(一维数组的代码)

二、需要思考的问题

问题一:0-1背包问题怎么用二维数组实现?

回答一:(见上图,详细解释一下递推关系)

问题二:用二维数组实现的时候,两个for循环颠倒一下顺序可不可以?

回答二:可以

问题三:0-1背包问题怎么用二维数组实现?

回答三:(见上图,详细解释一下递推关系)

问题四:用一维数组实现的时候,两个for循环颠倒一下顺序可不可以?

回答四:不可以。因为先遍历物品就相当于先遍历行,而一维数组需要一行一行遍历,也只能一行一行遍历。

问题五:用一维数组实现的时候,第二个for循环为什么是从后往前?为什么不能从前往后?

回答五:因为当前的一维数组存的是上一层的数据,需要在当前位置计算出新数据的时候要借助当前位置前面的旧数据,所以不能从前往后。否则当前位置的前面就是新数据了。我们计算的时候需要当前位置的前面的旧数据。

问题六:为什么前面用二维数组实现的时候,第二个for循环就是从前往后或者从后往前都可以?一维数组的第二个for循环就必须从后往前

回答六:因为二维数组计算当前位置的结果时需要借助旧数据,这个旧数据在上一层,不存在旧数据可能被覆盖的情况,所以二维数组的第二个for循环从前往后或者从后往前都可以。但是一维数组第二个for循环从前往后计算新数据的时候,会把旧数据覆盖,后面的位置将无法计算出正确的结果。

相关推荐
小小编程路1 小时前
字符串转数字时,可能会遇到哪些问题?
java·开发语言·算法
rit84324992 小时前
MATLAB近红外光谱预处理:平滑与求导(MSV方法)
数据结构·算法·matlab
蚂蚁数据AntData2 小时前
从ChatBI到业务记忆:重新定义数据智能的生产力边界
大数据·网络·数据库·人工智能·算法
_日拱一卒2 小时前
LeetCode:22括号生成
算法·leetcode·职场和发展
cfm_29142 小时前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
郝学胜_神的一滴2 小时前
干货版《算法导论》09:让哈希表稳如泰山的终极解法
数据结构·算法
CC数学建模2 小时前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题C题:创业社区规划与资源配置优化问题完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
徐小夕2 小时前
我们放弃了单Agent方案:HiCAD 3.0 用 Harness 做多Agent编排,把3D建模的准确率提升了30%
前端·算法·github
洛水水2 小时前
【力扣100题】88.多数元素
数据结构·算法·leetcode