解题思路:
转化为01背包问题,集合中每个元素只能用一次,看能不能凑出sum//2这个重量。(重量值=价值值)
dp含义:前重量j所获得的最大价值
递推公式:dp[j] = max(dp[j],dp[j-numbers[i]] + numbers[i])
初始化:dp[0] = 0,非0下标也初始为0
遍历顺序:
一维的滚动dp数组必须注意遍历顺序,先物品再背包(倒序)
代码实现:(需要判断最终dp[num] = num,num = sum//2)
解题思路:
转化为01背包问题,集合中每个元素只能用一次,看能不能凑出sum//2这个重量。(重量值=价值值)
dp含义:前重量j所获得的最大价值
递推公式:dp[j] = max(dp[j],dp[j-numbers[i]] + numbers[i])
初始化:dp[0] = 0,非0下标也初始为0
遍历顺序:
一维的滚动dp数组必须注意遍历顺序,先物品再背包(倒序)
代码实现:(需要判断最终dp[num] = num,num = sum//2)
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/475004.html
如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!