[AcWing算法基础课]动态规划之01背包

题目链接:01背包

        有 N 件物品和一个容量是 V 的背包。每件物品只能使用一次第 i 件物品的体积是 vi,价值是 wi。求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。输出最大价值。

        首先,我们应该找到“01背包”问题的一个特点就是每件物品只能使用一次。 对于每一个物品,我们只需要考虑“选”或“不选”,这可能就是名字的来源吧。

        “01背包”问题适合使用动态规划算法解决,也就是“记住求过的解来节省时间”。

        下面先给出“01背包”问题的模板:

    // v[i]->体积  w[i]->价值 // f[i][j] 放入第i个物体,背包容量为j时的总价值for(int i = 1;i <= n;i++){  //动态规划for(int j = 0;j <= m;j++){if(v[i] <= j){f[i][j] = max(f[i-1][j],f[i-1][j-v[i]]+w[i]);}}}int res = 0;  //最优解for(int j = 0;j <= m;j++){res = max(res,f[n][j]);}

        接下来给大家举一个例子演示一下,方便大家理解。

        我们假设有4个物品,并把每一个物品响应的体积和价值标注出来(下图的左侧),然后设置书包的体积为5。大家应该可以发现:

  • 放入0个物品时,无论体积为多少,价值都为0。所以第一行全部填0
  • 当书包的体积为0时,不能放入任何物品,价值也都为0。所以第一列全部填0

        接下来看放入第1个物品会发生什么变化,也就是完善第二行 。

        便于理解的解释:第1个物品的体积为1,价值为2。当书包体积 j = 1时, j = v [ i ],可以放入第1个物体,故此时书包的价值为2。当书包体积 j > 1时, j > v [ i ],都可以放入第1个物体,故此时书包的价值仍然为2。第二行填完了。

        基于代码的解释:当书包体积 j = 1时,我们考虑是否放入第1个物品:

  • 不放入,那么书包的价值 f [1][1] 和 f [0][1]相同。(没放入任何物品,无论书包体积为多少,书包的价值都为0)。
  • 放入,那么书包的价值 f [1][1] 就应该看放入第0个物品,书包的体积为1减去第1个物品的体积1时,书包的价值(1 - 1 = 0)。简单来说,现在书包的体积(j = 1)减去第1 个物品的体积 (v [1] = 1)应该等于放入第0个物品时书包的体积(j - v [1] = 1 - 1 = 0)。只有放入第0个物体,书包体积为0时,我才能在书包体积为1时放入第1个物体,否则放不下。

        对于这两种情况,我们应该选择最优的方法,也就是比较这两种方法的价值,取最大值。

        接下来看放入第2个物品会发生什么变化,也就是完善第三行 。

        接下来看放入第3个物品会发生什么变化,也就是完善第四行 。

        接下来看放入第3个物品会发生什么变化,也就是完善第四行 。 

 

        以上就是动态规划的“01背包”求解过程,大家多模拟几遍肯定会有更多的感悟!

        希望大家学有所获!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/12103.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

标准、高效的管理测试用例和活动

送您一份新人礼&#xff0c;自动化测试平台限时免费体验~ 本文主要介绍测试用例管理的基础知识和基本使用方法&#xff0c;帮助您快速管理测试用例及活动。 操作流程 用例管理的主要使用流程如下&#xff1a; 1.新建测试用例 2.评审测试用例 3.创建测试计划 4.执行测试计划 5…

如何在jupyter notebook切换python环境

目录 1、切换到目标python环境&#xff0c;假设我的是叫“tf” C:\Users\hello>activate tf(tf) C:\Users\hello>2、安装notebook内核包 (tf) C:\Users\hello>pip install ipykernel3、将环境加入到notebook中 python -m ipykernel install --user --name pytorch --…

windows工具 -- 使用SpaceSniffer查看哪些文件夹占用那么大空间, 再也不用右键属性了

目的 C盘不知道哪些文件夹占用了那么多空间, 右键属性扫描太慢了 效果 运行效果 静态截图 下载使用 下载 SpaceSniffer https://github.com/redtrillix/SpaceSniffer/releases 解压到文件夹后, 双击运行

[DEBUG] 服务器 CORS 已经允许所有源,仍然有 304 的跨域问题

背景 今天有一台服务器到期了&#xff0c;准备把后端迁移到另一台服务器上&#xff0c;结果前端在测试的时候&#xff0c;出现了 304 的跨域问题。 调试过程中出现的问题&#xff0c;包括但不限于&#xff1a; set the request’s mode to ‘no-cors’Redirect is not allow…

智慧园区解决方案:科技赋能,打造未来管理新典范

智慧园区作为城市发展的重要组成部分&#xff0c;正以前所未有的速度蓬勃发展。随着5G、云计算、大数据、物联网&#xff08;IoT&#xff09;、BIM&#xff08;建筑信息模型&#xff09;、人工智能&#xff08;AI&#xff09;及区块链等前沿技术的日益成熟与融合应用&#xff0…

CTF记录

1. [SWPUCTF 2022 新生赛]android 用jadx打开&#xff0c;然后搜索NSS关键字 NSSCTF{a_simple_Android} 2. [SWPU 2024 新生引导]ez_SSTI 模板注入题目&#xff0c;直接焚靖可以秒了 填入数据 ls / 然后 cat /flag即可 获取成功 NSSCTF{2111e7ad-97c5-40d5-9a3b-a2f657bd45e8…

Vue使用富文本编辑器vue-quill-editor

Vue使用富文本编辑器 1. 安装 npm install vue-quill-editor -S2. 引入到项目中 有两种挂载方式&#xff1a; 全局挂载 和 在组件中挂载&#xff0c;根据自己的项目需求选择&#xff0c;一般用到富文本编辑都是在某一个项目中&#xff0c;我们这里为了方便大家选择&#xff…

AUTOSAR_EXP_ARAComAPI的7章笔记(2)

☞返回总目录 相关总结&#xff1a;服务发现实现策略总结 7.2 服务发现的实现策略 如前面章节所述&#xff0c;ara::com 期望产品供应商实现服务发现的功能。服务发现功能基本上是在 API 级别通过 FindService、OfferService 和 StopOfferService 方法定义的&#xff0c;协议…

windows yolo11 自定义训练

一、在yolo11源码文件夹创建一个train.py 内容如下&#xff1a; from ultralytics import YOLOif __name__ __main__:model YOLO(rultralytics/cfg/models/11/yolo11.yaml)model.train(datarD:/yolo11/WiderPerson_yolo/WiderPerson_yolo/WiderPerson_yolo.yaml,imgsz(640,3…

简述 synchronized 和 java.util.concurrent.locks.Lock 的异同?

大家好&#xff0c;我是锋哥。今天分享关于【简述 synchronized 和 java.util.concurrent.locks.Lock 的异同&#xff1f;】面试题。希望对大家有帮助&#xff1b; 简述 synchronized 和 java.util.concurrent.locks.Lock 的异同&#xff1f; 在Java编程中&#xff0c;synchro…

C语言中,“extern”关键字的含义与用法

在C语言中&#xff0c;extern 关键字用于声明一个已经在其他地方定义的变量或函数。它的主要作用是告诉编译器&#xff0c;某个变量或函数是在当前文件之外定义的&#xff0c;编译器应该在链接阶段找到这个变量或函数的实际定义。以下是 extern 的一些常见用途和用法&#xff1…

TCP最后一次握⼿连接阶段,如果ACK包丢失会怎样?

2024年10月NJSD技术盛典暨第十届NJSD软件开发者大会、第八届IAS互联网架构大会在南京召开。百度文心快码总经理臧志分享了《AI原生研发新范式的实践与思考》&#xff0c;探讨了大模型赋能下的研发变革及如何在公司和行业中落地&#xff0c;AI原生研发新范式的内涵和推动经验。 …

【大数据学习 | HBASE】hbase的读数据流程与hbase读取数据

1. hbase的读数据流程 在解析读取流程之前我们还需要知道两个功能性的组件和HFIle的格式信息 HFILE 存储在hdfs中的hbase文件&#xff0c;这个文件中会存在hbase中的数据以kv类型显示&#xff0c;同时还会存在hbase的元数据信息&#xff0c;包括整个hfile文件的索引大小&…

AI基础知识

目录 1.激活函数:one: 激活函数的作用:two: sigmoid函数:three: tanh函数:four: ReLu:five: Leaky ReLU 2.Softmax函数3.优化器:one: 优化器的作用:two: BGD&#xff08;批梯度下降&#xff09;:three: SGD&#xff08;随机梯度下降&#xff09;:four: MBGD&#xff08;Mini Ba…

01背包问题(DP)

2. 01背包问题 - AcWing题库 DP做题思路分析 实现代码&#xff1a; #include <iostream> #include <algorithm>using namespace std;const int N 1010;int n , m; int v[N],w[N],dp[N][N];int main() {cin >> n >> m;for (int i 1;i < n;i) {ci…

如何提升自媒体发稿效果,必须掌握的几个技巧

在自媒体时代&#xff0c;发稿效果直接关系到内容的传播力与影响力。为了提升自媒体发稿效果&#xff0c;有几个关键技巧是每位自媒体人必须掌握的。以下是对这些技巧的详细阐述&#xff1a; 一、明确受众定位 首先&#xff0c;自媒体人需要明确自己的受众群体。这包括受众的…

充电桩基础设施的时空大数据分析:以深圳市为例

随着全球对可持续交通解决方案的需求不断增长&#xff0c;电动汽车&#xff08;EV&#xff09;作为减少交通领域碳排放的重要手段&#xff0c;受到了广泛的关注。然而&#xff0c;电动汽车的普及和发展面临着诸多挑战&#xff0c;其中充电基础设施的建设和管理尤为关键。为了更…

将数组中的数据反向输出(数组,函数)

将数组中的数据反向输出&#xff0c;用数组名作函数参数 swap函数是用来实现数组中元素前后的调换&#xff0c;用这种方式来实现数组中元素的逆序输出 #include <stdio.h> #include <stdlib.h> void swap(int m[],int n); int main() {int a[]{1,2,3,4,5,6,7,8,9,…

【Matlab算法】MATLAB实现基于小波变换的信号去噪(附MATLAB完整代码)

MATLAB实现基于小波变换的信号去噪 结果图前言正文1. 小波变换理论基础1.1 小波变换的数学模型1.2 离散小波变换原理2. 信号去噪方法2.1 去噪算法流程2.2 阈值处理方法3. 核心函数解析3.1 wavedec函数3.2 wthresh函数代码实现4.1 信号生成4.2 小波变换去噪完整代码总结参考文献…

01-JavaSE课程总体介绍

适合人群 课程体系 学完本阶段&#xff0c;至少得到以下收货 学习内容&#xff08;视频课件源码&#xff09; 资料领取 JavaSE课程 更多资料获取&#xff0c;请联系星主