当前位置: 首页 > news >正文

【代码随想录day 35】 力扣 01背包问题 一维

视频讲解:https://www.bilibili.com/video/BV1BU4y177kY/?vd_source=a935eaede74a204ec74fd041b917810c
文档讲解:https://programmercarl.com/%E8%83%8C%E5%8C%85%E7%90%86%E8%AE%BA%E5%9F%BA%E7%A1%8001%E8%83%8C%E5%8C%85-2.html#%E6%80%9D%E8%B7%AF
力扣题目:https://kamacoder.com/problempage.php?pid=1046

这道题和上一道题一样,只不过改成了一维数组。
首先我们要知道为什么可以改成一维数组,因为我们只需要一行的数据,每次从上往下遍历物品的时候可以直接在本数组上更新,所以使用一维滚动数组就够了,但是需要注意一点,在二维数组种,我们更新ij的结果是根据ij的左上角数组更新的,如果要在一维数组中进行就是说要根据前面的数来更新后面的值,所以在更新新的一行时,我们要从后往前更新,保留之前的值才能更新下一个数组的右边的值,也就是后序遍历。
还是动态规划五步法:

  1. dp[j]的含义:dp[j]表示容量为j的背包在当前物品i的最大价值的装法
  2. 递推公式:dp[j]要自己更新自己,就是本身跟装i的取最大值,即为dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);
  3. 初始化物品0在不同背包容量的情况(其实这一步可以省略,在遍历顺序可以直接用初始化为0的数计算)
  4. 遍历顺序,从上往下,先遍历物品种类,在遍历背包容量,在同一层遍历当中dp[j]需要dp[j]和dp[j - weight[i]]的值,因此前边的值改变会影响后面的值的更新,我们需要采用后续遍历,这样可以更新新的值也不会影响前面的值
  5. 打印dp数组。
#include <bits/stdc++.h>
using namespace std;int main()
{//初始化物品M种,总容量Nint M, N;cin >> M >> N;vector<int> value(M);vector<int> weight(M);for(int i = 0; i < M; ++i){cin >> weight[i];}for(int i = 0; i < M; ++i){cin >> value[i];}//1.dp[j]的含义:dp[j]表示容量为j的背包在当前物品i的最大价值的装法vector<int> dp(N + 1, 0);//2.递推公式:dp[j]要自己更新自己,就是本身跟装i的取最大值,即为dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);//3.初始化物品0在不同背包容量的情况for(int j = 0; j <= N; ++j){//如果背包空间比物品0的大小还要小,dp[j]为0,否则dp[j]=物品0的价值if(j < weight[0]){dp[j] = 0;continue;}dp[j] = value[0]; }//4. 遍历顺序,从上往下,先遍历物品种类,在遍历背包容量//在同一层遍历当中dp[j]需要dp[j]和dp[j - weight[i]]的值,因此前边的值改变会影响后面的值的更新,我们需要采用后续遍历,这样可以更新新的值也不会影响前面的值for(int i = 1; i < M; ++i){//倒序遍历,使用后面更新前面for(int j = N; j >= weight[i]; --j){dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);}}cout << dp[N] << endl;return 0;}
http://www.dtcms.com/a/446455.html

相关文章:

  • 湖南网站开发公司电话江门网站
  • 适用于自动化脚本的PDF查看器?
  • 高校网站首页设计wordpress 自动保存
  • 机器学习中的决策树
  • 洛谷 - dp 题目详解 4(超详细版)
  • Weight decay 和 L2 Regularization
  • 游戏源码网站免费企业网站建设教程 pdf
  • 全网品牌营销泰安搜索引擎优化招聘
  • Win11上VS Code免输密码连接Ubuntu的正确设置方法
  • 江西建设推广网站百度seo培训课程
  • 基于RT-Thread的STM32开发第十讲——CAN通讯
  • Transformer时序预测模型对比传统LSTM的优劣
  • 随机试验中异质性处理效应的通用机器学习因果推断
  • ClaudeCode真经第七章:未来发展与技术展望
  • 利用DeepSeek辅助给duckdb_pgwire插件添加psql终端输出int128功能
  • 做网站在百度云盘登录
  • 亿企邦网站建设服务器租用免费试用
  • Coze源码分析-资源库-编辑知识库-后端源码-应用/领域/数据访问层
  • 做移动网站点击软件吗网站后台管理系统安装
  • 网站统计排名哪家网站雅虎全球购做的好
  • 福彩体彩10月5号数据分享
  • Java——文件相关知识
  • Hadess入门到实战(7) - 如何管理Pypi(Python)制品
  • RDMA 技术解析(1):RDMA 技术三国志 ——IB、RoCE、iWARP 的选型博弈
  • wordpress文章提交江苏网站快速排名优化
  • 【自记】MaxCompute中的冒烟测试
  • Linux : 动静态库制作、ELF格式
  • 如何制作电脑公司网站关键词怎么优化到百度首页
  • seo的全称是什么广州关于进一步优化
  • 南京设计网站免费做网站tk