代码随想录算法训练营第三十五天 | 01背包问题 二维,01背包问题 一维,416. 分割等和子集

news/2024/9/23 21:45:06/

三十五天打卡,背包问题入门,之前做过还是比较容易的


46.卡码网【携带研究材料】

题目链接

解题过程

  • 采用二维bp,bp[i][j]的含义是,背包容量为j,只装序号为0~i的物品时能装的最大价值
  • 若背包容量大于等于当前物品的重量,可以选择装或者不装
    • dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]);
  • 若背包容量小于当前物品的重量,只能选择不装
    • dp[i][j] = dp[i - 1][j];

二维dp

#include<iostream>
#include<vector>
using namespace std;
int main() {int m, n;cin >> m >> n;vector<int>weight(m);vector<int>value(m);for (int i = 0; i < m; i++) {cin >> weight[i];}for (int i = 0; i < m; i++) {cin >> value[i];}vector<vector<int>>dp(m, vector<int>(n + 1));for (int j = weight[0]; j <= n; j++) {dp[0][j] = value[0];}for (int i = 1; i < m; i++) {for (int j = 0; j <= n; j++) {if (weight[i] <= j) {dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]);} else {dp[i][j] = dp[i - 1][j];}}}cout << dp.back().back();return 0;}

解题过程

  • 采用一维dp,bp[j]的含义是,背包容量为j,能装物品的最大价值
  • dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);
  • 倒序遍历是为了让所有物品只被放入一次

一维dp

#include<iostream>
#include<vector>
using namespace std;
int main() {int m, n;cin >> m >> n;vector<int>weight(m);vector<int>value(m);for (int i = 0; i < m; i++) {cin >> weight[i];}for (int i = 0; i < m; i++) {cin >> value[i];}vector<int>dp(n + 1);for (int i = 0; i < m; i++) {for (int j = n; j >= 0; j--) {if (j >= weight[i]) {dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);}}}cout << dp.back();return 0;}

416.分割等和子集

题目链接

解题过程

  • 采用背包问题解法,背包容量为sum / 2,物品的重量和价值都为num[i]
  • 背包如果正好装满,说明找到了总和为 sum / 2 的子集。
  • 本题中我们要使用的是01背包,因为元素我们只能用一次。
  • dp[j]表示 背包总容量(所能装的总重量)是j,放进物品后,背的最大重量为dp[j]

01背包

class Solution {
public:bool canPartition(vector<int>& nums) {int target = 0;int sum = 0;for (int n : nums) sum += n;if (sum % 2 == 1) return false;target = sum / 2;vector<int>dp(target + 1);for (int i = 0; i < nums.size(); i++) {for (int j = target; j >= 0; j--) {if (j >= nums[i]) {dp[j] = max(dp[j], dp[j - nums[i]] + nums[i]);}}}return dp.back() == target;}
};

http://www.ppmy.cn/news/1529502.html

相关文章

【HTTP】方法(method)以及 GET 和 POST 的区别

文章目录 方法&#xff08;method&#xff09;登录上传GET 和 POST 有什么区别&#xff08;面试&#xff09;区别不准确的说法 方法&#xff08;method&#xff09; 首行中的第一部分。首行是由方法、URL 和版本号组成 方法描述了这次请求想干什么&#xff0c;最主要的是&…

运维工程师面试整理-沟通能力

在运维工程师的面试中,沟通能力是一个关键的软技能。虽然运维工程师的工作主要集中在技术领域,但良好的沟通能力能够帮助你更有效地与团队成员、其他技术部门和非技术人员协作。以下是关于运维工程师需要具备的沟通能力的详细内容,帮助你更好地准备面试。 1. 沟通能力的重要…

植物大战僵尸【源代码分享+核心思路讲解】

植物大战僵尸已经正式完结&#xff0c;今天和大家分享一下&#xff0c;话不多说&#xff0c;直接上链接&#xff01;&#xff01;&#xff01;&#xff08;如果大家在运行这个游戏遇到了问题或者bug&#xff0c;那么请私我谢谢&#xff09; 大家写的时候可以参考一下我的代码思…

oracle生成时间戳字符的两种方法

在Oracle中&#xff0c;生成时间戳字符串可以通过两种方式实现&#xff1a;使用SYSTIMESTAMP函数和使用TO_CHAR函数。 方法一&#xff1a;使用SYSTIMESTAMP函数 SELECT SYSTIMESTAMP FROM DUAL; 方法二&#xff1a;使用TO_CHAR函数 SELECT TO_CHAR(SYSTIMESTAMP, YYYY-MM-D…

关闭小广告【JavaScript】

在 JavaScript 中实现关闭小广告的功能&#xff0c;可以通过监听点击事件来隐藏广告元素。 实现效果&#xff1a; 代码&#xff1a; <!DOCTYPE html> <html lang"zh"><head><meta charset"UTF-8"><meta name"viewport&q…

更新了,图片美化工具迎来两大功能

最近给图片套壳美化工具更新了两个重要的功能&#xff0c;简而言之就是&#xff1a; 直接操作图片的放大缩小快速截图后上传图片&#xff08;通过浏览器的 getDisplayMedia 接口&#xff09; 第一个功能是为了方便操作&#xff0c;之前是在左侧通过滑动区块来调节图片区域的显示…

【LLM论文日更】| 俄罗斯套娃嵌入模型

论文&#xff1a;https://proceedings.neurips.cc/paper_files/paper/2022/file/c32319f4868da7613d78af9993100e42-Paper-Conference.pdf代码&#xff1a;GitHub - RAIVNLab/MRL: Code repository for the paper - "Matryoshka Representation Learning"机构&#x…

MATLAB数据文件读写:1.格式化读写文件

格式化读写文件 matlab提供了对数据文件建立、打开、读取、写入、关闭等操作的函数。 数据文件可以分为两类&#xff1a; 文本文件&#xff1a;以ASCII码形式存储的文本文件&#xff1b;编码基于字符定长&#xff0c;译码相对容易二进制文件&#xff1a;以二进制形式存储的文…