背包问题求助

在n个物品中挑选若干物品装入背包,最多能装多满?假设背包的大小为m,每个物品的大小为A[i]。
基础解决方法是二维状态数组,然后有个优化空间的解决办法——用一维状态数组。

不懂的地方是为什么双重循环里第二个要倒序
网上看到两种解释:
1. 正序枚举A[i],并倒叙枚举j,这样所需要的dp[j-A[i]]不会被提前更新

2,因为新的结果要与其在二维素组中左上位置的元素比较(即一维数组中左边的元素比较),所以从后向前遍历一维数组

但是都看不太懂,有没有好心人愿意探讨一下#晒一晒我的offer##现在还是0offer,延毕还是备考##0offer是寒冬太冷还是我太菜#(引流)
全部评论
因为如果用一维背包且正序遍历,考虑把当前的物体放进背包时需要j-A【i】的状态,而这个状态如果是正序遍历就是已经被计算过了(即已经考虑要不要把当前物体放进背包了),这样就相当于一个物体可以被多次选择了,变成了完全背包问题。所以对于01背包一维dp需要倒序遍历
1 回复 分享
发布于 2023-09-26 23:30 江苏

相关推荐

要冲外企的祖国花朵很温柔:今年有签约礼盒嘛
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客企业服务