
网问答>>代码随想录算法训练营第三十五天| 携带研究材料(01背包)、416. 分割等和子集
问题
代码随想录算法训练营第三十五天| 携带研究材料(01背包)、416. 分割等和子集
时间:2026-03-25 11:40:02
代码随想录算法训练营第三十五天| 携带研究材料(01背包)、416. 分割等和子集
最佳回答
01背包问题是动态规划中的经典问题,其核心在于在有限的背包容量下选择物品以最大化价值。以下是对01背包问题的详细解析,包括二维和一维动态规划的实现方法,以及其在416. 分割等和子集问题中的应用。01背包问题二维动态规划状态定义:dp[i][j]表示在前i件物品中选择,且背包容量不超过j时能获得的最大价值。状态转移:不选第i件物品:dp[i][j] = dp[i-1][j]选第i件物品(前提是j = w[i]):dp[i][j] = max(dp[i-1][j], dp[i-1][j-w[i]] + v[i])初始化:当容量j=0时,dp[i][0] = 0。当没有物品时(i=0),所有dp[0][j] = 0。填表顺序:外层循环物品i,内层循环容量j,逐个填充DP表。结果:dp[m][n]即为在m件物品中选择,背包容量不超过n的最大价值。一维动态规划(滚动数组优化)降维思路:用一维数组dp[j]来表示容量为j时的最大价值。更新顺序:从大到小遍历容量,确保每个物品只被用一次。状态转移:for (int j = W; j = weight[i]; j--) { dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);}倒序遍历的原因:避免同一物品被重复计算,保证每个物品只用一次。416. 分割等和子集问题转化目标:将数组分成两个子集,使得两个子集的和相等。转化:判断能否从数组中挑出一部分数,使得它们的和等于sum(nums)/2。特殊情况处理:如果总和是奇数,直接返回false。背包模型背包容量:target = sum(nums)/2。物品:每个元素num看作一个物品,重量和价值均为num。问题:能否用这些物品恰好装满容量为target的背包。动态规划定义定义:dp[j]表示容量为j时,是否能被若干个数填满。初始化:dp[0] = true(背包容量0一定能装满)。状态转移遍历每个数:倒序遍历j从target到num:dp[j] = dp[j] || dp[j - num];解释:要么不用当前数,维持原状;要么用当前数,看能不能填满j-num。最终结果判断:看dp[target]是否为true。代码实现01背包问题(一维DP)#include iostream#include vectorusing namespace std;int main() { int m, n; scanf("%d%d", &m, &n); vectorint space(m + 1); vectorint value(m + 1); for (int i = 1; i = m; i++) scanf("%d", &space[i]); for (int i = 1; i = m; i++) scanf("%d", &value[i]); vectorint dp(n + 1, 0); for (int i = 1; i = m; i++) { for (int j = n; j = space[i]; j--) { dp[j] = max(dp[j], dp[j - space[i]] + value[i]); } } cout dp[n] endl; return 0;}416. 分割等和子集class Solution {public: bool canPartition(vectorint& nums) { if (nums.size() == 1) return false; int sum = 0; for (int num : nums) sum += num; if (sum % 2) return false; int target = sum / 2; vectorbool dp(target + 1, false); dp[0] = true; for (int num : nums) { if (num target) return false; for (int j = target; j = num; j--) { dp[j] = dp[j] || dp[j - num]; } if (dp[target]) return true; } return dp[target]; }};复杂度分
时间:2026-03-25 11:40:10
本类最有帮助
- 关于贵巢床垫,听说其环保性能怎么样呢?
- 喜元帅瓷砖属于几线品牌?
- 长安的荔枝被禁播了么
- 这是边牧串吗?
- 云彩石地坪漆有什么优势?家里能用吗?
- 针对一般家庭装修,云彩石品牌提供怎样的组合方案?
- 听说藏天参和普通人参存在区别,为什么它的价格会更
- 叶良柱为什么选择给家具涂木蜡油而不是化学漆呢?
- 王浩输给过谁
- 小人全部滚。。。别想合好。。一个字穷?
- 包头包钢友谊宾馆酒店介绍
- 为啥应该感谢别人帮忙,但是有些人是要求别人感谢他
- 感恩是怎么来的,为啥有的人劝人目的是别人必须感谢
- 关于央心心理咨询,目前它的收费贵不贵呢?
- 关于央心心理咨询,第一次体验目前感觉如何?
- 对于央心心理咨询APP,收费标准是怎样的?
- 关于央心心理咨询,听说有线下机构分布吗?
- 二把手做好二把手
- 他对我有意思吗?
- 我喜欢你和能做我女朋友吗哪个正式有仪式感?
- 教师节写给教师的贺卡祝福贺词
- 以前很珍贵的应用,不小心删了,然后又忘了他的名字
- 以前很珍贵的赚钱应用,不小心删了,然后又忘了他的
- 最近麻烦事多,工作干不下去做不开心,新工作又不可
- 为什么我总是被用别人的咒骂语才能把自己隐藏到人群
- 一个未婚大龄女性,被一个已婚有子女的女人骂绝子绝
- 汽修兄弟们,有没有轻巧还贼拉带劲的电动扳手?
- 新国标电动车能解限速吗
- 光伏发电组成部分?
- 光伏板最多串联多少组?
- 光伏板之间怎么连接?
- 炫潮隐形车衣怎么样?
- 炫潮隐形车衣值得购买吗?
- 隐形车衣炫潮怎么样?
- 汽车解码器进不到系统是什么原因?
- 自由光喇叭什么牌子
- 炫潮品牌隐形车衣质量怎么样?
- 简单回答一下发动机电脑控制点火系统的工作过程
- 2014年A8发动机电脑版多少钱?
- 鉴别本田割草机真假识别
- 关于店商豹,它是怎么赚钱的?
- 当前银监会能否帮助协商还款
- 重庆丰都中学高考成绩亮眼
- 广东岭南职业技术学院有几个校区?地址分别在哪?
- 马明义平凉一中校长
- 广东岭南职业技术学院从广州天河区如何到达清远校区
- 长沙市通航中等职业学校是中专还是大专?可以学哪些
- 手机第一次充电充多长时间好?
- 怎么刷机?
- 王老师买粉笔用去29元7角,买墨水用去57元9角,她付
网问答为提供知识和解答各类疑难的平台,目标是做到有问必答解决您遇到的各类问题.本站内容均为网友发表,并不代表本站立场!
Copyright © 2008-2013 www.wangwenda.com All rights reserved.冀ICP备12000710号-1
投诉邮箱: