
网问答>>代码随想录算法训练营第三十五天| 携带研究材料(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
本类最有帮助
- 阿克苏市农村低保标准多少钱一个月
- 信访政府人员直接到家里怎么办
- 我的麻雀已经没有了怎么办我也不知道他是怎么死的?
- 公安部有没有规范退还取保候审金
- 被下了尸油降头术怎么办
- 满街都是补牙的城市?
- 如何让磁共振不跑液氦?
- 大腿根长了东西?
- 小六壬怎么算具体步骤
- 修法的人脉象和普通人的脉象有区别吗
- 祝由术手法能去除乳腺结节吗?
- 医院药房实习主要任务与目标
- 青岛市中心医院属于几级医院?
- 长春哪里有调理糖尿病比较好的地方啊?
- 孩子反复感冒咳嗽,每次都去儿童医院,太折腾了,北
- 醋膏能降血脂吗?如何服用?
- 长效和短效生长激素哪个更适合家庭注射?
- 黎平县有助听器吗?
- 生长激素哪个牌子不容易产生抗体?
- 想给孩子买点护眼的东西,看到有护眼仪、护眼灯、还
- 熬夜、劳累会不会加重听感变差的情况?
- 不净观能对治贪欲吗?
- 从阿克苏站到阿克苏地区维吾尔医院坐几路公交
- 修法的人脉象和普通人的脉象有区别吗
- 小六壬怎么算具体步骤
- 医疗比信访局更有效的部门有哪些
- 迈之灵胶囊是缴素药吗?
- 鹏瑞利国名医院是做什么的际?
- 包皮里面发红应该涂什么药?
- 阑尾炎手术伤口恢复后有疤痕怎么消除?
- 医保卡在药店是不是不能随便刷了?个账“白名单”是
- 清鼻堂治疗鼻炎效果好不好?
- 清鼻堂治鼻炎价格贵吗?
- 76岁的老人,检查出食道癌,可以做手术吗?
- 广州穗岁康和百万医疗险到底有什么区别?有了穗岁还
- 16岁心脏不好没有上学不会用电脑的在家里可以上什么
- 金质习酒的酒瓶具体是什么材料制作的
- 澳门新濠天地水舞间表演一场多久
- 毛主席相挂在电视墙上面可不可以?
- 毛主席瓷像放客厅哪个方向好
- 西藏传统节日雪顿节主要活动是?a、跳锅庄b、藏马c、
- 毛主席铜像可放办公桌后开放式橱柜里吗
- 家中客厅内摆毛主席像如何
- 乌鲁木齐学习家居修复哪家好
- 毛主席雕像摆在家里什么位置最合适
- 新疆人不能留什么胡子
- 几月份吃扇贝味道最棒
- 一年中什么时候吃扇贝口感最好
- 凤起路打车到雷锋塔多少钱
- 习酒公司出品的绿色瓶身的盒装白酒具体是哪一款
网问答为提供知识和解答各类疑难的平台,目标是做到有问必答解决您遇到的各类问题.本站内容均为网友发表,并不代表本站立场!
Copyright © 2008-2013 www.wangwenda.com All rights reserved.冀ICP备12000710号-1
投诉邮箱: