代码随想录算法训练营第四十四天|km46. 携带研究材料、 416. 分割等和子集

ops/2024/9/23 3:08:48/

代码随想录算法训练营第四十四天

km46. 携带研究材料

题目链接:km46. 携带研究材料

  1. 确定dp数组以及下标的含义:i的含义是物品编号从0到i,j的含义是当前背包的最大容量,dp[i][j]背包内物品的总价值
  2. 确定递推公式:背包最大容量固定为j,每个循环尝试在当前最大容量下,把物品往背包里试着放一下,面临2种情况:
    1. 最大容量不够放入当前选择的物品,背包内最大的价值就是原来的dp[i-1][j],
    2. 最大容量能放下当前选择的物品,价值为dp[i-1][j-space[i]]+value[i],将space[i]这么多空间价值的物品取出,在把当前物品的价值放进去的总价值,或者不进行这个交换的总价值哪个更大
  3. dp数组如何初始化:背包容量为0,没法放物品,价值就都是0,dp[0][0]到dp[i][0]都是0;背包总空间能放下第一个物品,包内物品的价值就是第一个物品的价值,dp[0][space[0]]到dp[0][j]都是value[0]。
  4. 确定遍历顺序:从小到大
  5. 打印dp数组。
#include <iostream>
#include <vector>
using namespace std;
int main(){int M;int N;std::cin>>M>>N;std::vector<int> space(M);std::vector<int> value(M);for(int i=0;i<M;i++){std::cin>>space[i];}    for(int i=0;i<M;i++){std::cin>>value[i];}vector<vector<int>>dp(M,vector<int>(N+1,0));for(int i =space[0];i<=N;i++){dp[0][i]=value[0];//能装的情况下把物品1都装进去}for(int i =1;i<M;i++){for(int j=0;j<=N;j++){if(j<space[i])dp[i][j] = dp[i-1][j];//当前物品占用空间大于背包空间,装不了else dp[i][j]=max(dp[i-1][j],dp[i-1][j-space[i]]+value[i]);//能装,把i物品需要空间的总价值减掉,再加上当前物品的价值,看看价值和不换哪个大// std::cout<<dp[i][j]<<" ";}// std::cout<<std::endl;}std::cout<<dp[M-1][N];return 0;
}

416. 分割等和子集

题目链接:416. 分割等和子集

  1. 确定dp数组以及下标的含义:dp[j]表示 背包总容量(所能装的总重量)是j,放进物品后,背的最大重量为dp[j]
  2. 确定递推公式:dp[j] = max(dp[j], dp[j - nums[i]] + nums[i]);
  3. 初始化:dp[0]=0
  4. 确定遍历顺序:从大到小
  5. 打印dp数组。
class Solution {
public:bool canPartition(vector<int>& nums) {int sum =0;for(int &i :nums){sum+=i;}if(sum%2==1)return false;int target = sum/2;vector<int>dp(100*100+1,0);for(int i =0;i<nums.size();i++){for(int j =target;j>=nums[i];j--){dp[j]=max(dp[j],dp[j-nums[i]]+nums[i]);}}if(dp[target]==target)return true;return false;    }
};


http://www.ppmy.cn/ops/45548.html

相关文章

动手学深度学习(Pytorch版)代码实践-深度学习基础-01基础函数的使用

01基础函数的使用 主要内容 张量操作&#xff1a;创建和操作张量&#xff0c;包括重塑、填充、逐元素操作等。数据处理&#xff1a;使用pandas加载和处理数据&#xff0c;包括处理缺失值和进行one-hot编码。线性代数&#xff1a;包括矩阵运算、求和、均值、点积和各种范数计算…

如何通过手机自学编程入门:探索四、五、六、七方面的学习路径

如何通过手机自学编程入门&#xff1a;探索四、五、六、七方面的学习路径 在信息爆炸的时代&#xff0c;手机已不仅仅是通讯工具&#xff0c;更是知识的宝库和学习的利器。对于渴望入门编程的初学者来说&#xff0c;手机自学编程成为了一种便捷而高效的选择。本文将围绕四个方…

初识C语言第三十天——设计三子棋游戏

目录 一.设计游戏框架 1.打印游戏菜单 2.输入选择判断&#xff08;玩游戏/游戏结束/输入错误重新输入&#xff09; 二、玩游戏过程设计 1.设计棋格存放棋子——二维数组 2.初始化棋盘——初始化为空格 3.打印棋盘——本质上就是打印数组 4.游戏过程——1.玩家走棋 2.…

探索k8s集群的存储卷 emptyDir hostPath nfs

目录 一 含义 查看支持的存储卷类型 emptyDir存储卷 1.1 特点 1.2 用途 1.3部署 二、hostPath存储卷 一 含义 容器磁盘上的文件的生命周期是短暂的&#xff0c;这就使得在容器中运行重要应用时会出现一些问题。首先&#xff0c;当容器崩溃时&#xff0c;kubelet 会重…

如果有多个文件夹,怎么快速获得文件夹的名字呢

上一篇写到怎么批量建立文件夹&#xff0c;那么怎么获取批量文件夹的名字呢&#xff1f; 一、啊这&#xff0c;这真是一个好问题二、这个得用Python&#xff08;文本末尾有打包程序&#xff0c;点击链接运行就可以了&#xff09;&#xff08;1&#xff09;首先建立一个py文件&a…

Linux 使用 yum安装 ELK服务,yum 安装elasticsearch和Kibana(未写完)

文章目录 环境准备ELK组件介绍安装Elasticsearch安装Kibana 丢弃下载ELK 服务安装包Elasticsearch安装 Tips:关闭elasticsearch https修改 es 启动内存 环境准备 ELK组件介绍 ElasticSearch &#xff1a; 是一个近实时&#xff08;NRT&#xff09;的分布式搜索和分析引擎&…

微信小程序区分运行环境

wx.getAccountInfoSync() 是微信小程序的一个 API&#xff0c;它可以同步获取当前账号信息。返回对象中包含小程序 AppID、插件的 AppID、小程序/插件版本等信息。 返回的对象结构如下&#xff1a; 小程序运行环境&#xff0c;可选值有&#xff1a;develop&#xff08;开发版&…

前端一个页面依赖多个接口解决之node接口聚合

首先先介绍一下页面的接口请求处理&#xff1a; 接口请求之间是否存在依赖性&#xff0c;主要有两种处理方式&#xff1a; 并行请求&#xff1a; 当这些接口彼此之间互不依赖时&#xff0c;可以同时发起多个请求。这时可以使用 Promise.all([…]) 来处理&#xff0c;这样可以…