01背包 模板1 2 总结

物品质量 w[0] w[1]  w[2] ....... w[n]                背包容量c               T

物品价值 v[0]  v[1]  v[2]  .......  v[n]              物品种类 n                N

 

(一)设DP(x,y)   表示  从前x项物品中  取出装入  体积为y的背包 的  物品的最大价值

          前x项物品(0---- x-1 , X)   去装          体积容量为y的背包  

 

     

                 |--------       0                                     当 x=0 或 y=0

 DP(x,y)     |                DP(x-1,y)                           不装 第x 种

                 |                 DP( x-1,y-w[x] )  +  v[x]        y-w[x]>=0  装 第x 种

 

 

 

 

 

 

 

 

 

(二)设DP(x,y) 表示   从第x项物品开始  到 第n项物品  中取物品装入  体积为y 的背包  的    得到的最大价值

 从第x项物品        (x,   x+1  ,  X+2  ,  x+3  , ...........M ......n)    

 

 

 

 

 

                |--------       0                                     当 x=M+1  或 y=0

 DP(x,y)     |                  DP(x+1,y)                           不装 第x 种

                 |                 DP( x+1,y-w[x] )  +  v[x]        y-w[x]>=0  装 第x 种

 

 

 

动态规划算法思想1:

设m[i][j]用来表示从前i项物品中区取出装入体积为j的背包的物品的最大价值。

其中i的范围为0到n,其中j的范围为0到c,程序要寻求的解为m[n][c]。

可以分以下三种情况:

①m[0][j]对所有的j的值为0(物品种类为0), m[i][0]对所有的i的值为0(体积为0)

②当前的体积j大于等于w[i]时, m[i][j]是下面两个量的最大值:m[i-1][j] (不装)和 m[i-1][j-w[i] ]+v[i] (装)

③当前的体积j小于w[i]时,m[i][j]等于m[i-1][j]

 

 

 

 

 

 

 

 

 

 

 

 

动态规划算法思想2:

设m[i][j]用来表示从第i项物品开始到第n项物品中取物品装入体积为j的背包的得到的最大价值。

其中i的范围为0到n-1,其中j的范围为0到c,程序要寻求的解为m[0][c]。

可以分为:

①m[n-1][j] 在当j>=0并且j< w[n-1] 时等于0(装不下),否则等于v[n-1] (可以装上)

②当前的体积j大于等于w[i]时, m[i][j]是下面两个量的最大值:m[i+1][j] 和 m[i+1][ j-w[i] ]+v[i]

③当前的体积j小于w[i]时,m[i][j]等于m[i+1][j]

 

 

 

转载于:https://www.cnblogs.com/2014acm/p/3908298.html

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Cling旨在提供一款高性能的C++ REPL

Cling是一款交互式C解释器&#xff0c;以LLVM和Clang为基础构建&#xff0c;其目标是通过超越编码-编译-运行-调试这个惯常的C工作流程提供生产力的飞跃。\\Cling提供了一个读取-求值-输出循环&#xff08;REPL&#xff09;&#xff0c;类似常见的Unix shell&#xff0c;并支持…

8月12号=》391页-395页

14.10  使用document对象 document对象既是HTMLDocument类的一个实例&#xff0c;也是DHTML模型中的一个对象。该对象除了可以使用标准DOM模型 的方法之外&#xff0c;还可以使用它如下几个常用方法。 close()&#xff1a;结束一个通过open方法打开的document对象。 open()&a…

matlab暂停音频,matlab 中的实时音频

matlab 中的实时音频音频系统工具箱™针对实时音频处理进行了优化. audioDeviceReader, audioDeviceWriter, audioPlayerRecorder,dsp.AudioFileReader 和 dsp.AudioFileWriter 器是为流式传输多通道音频而设计的, 它们提供了必要的参数, 以便您可以在吞吐量和延迟之间进行权衡…

js数组操作

2019独角兽企业重金招聘Python工程师标准>>> 1、数组的创建 var arrayObj new Array(); //创建一个数组 var arrayObj new Array([size]); //创建一个数组并指定长度&#xff0c;注意不是上限&#xff0c;是长度 var arrayObj new Array([element0[, element1[…

ubuntu php zip 安装教程,Ubuntu安装zip解压软件

如果没安装&#xff1a;C/C Code复制内容到剪贴板sudo apt-get install unzipsudo apt-get install zip或者&#xff1a;C/C Code复制内容到剪贴板yum install zipyum install unzip【解压.zip文件】Ubuntu中貌似已经安装了unzip软件&#xff0c;解压命令如下&#xff1a;PHP C…

[hackerrank]Manasa and Stones

https://www.hackerrank.com/contests/w2/challenges/manasa-and-stones 简单题。 #include<iostream> using namespace std;int main() {int T;cin >> T;while (T--) {int n, a, b;cin >> n >> a >> b;// a < bif ( a > b) {int tmp a;a…

PHP--字符串处理函数

字符串的声明 1、 2、 3、 【注】单引号与双引号声明字符串的区别&#xff1a; 1、strlen():获取字符串长度 2、substr():截取字符串 3、strpos():查找字符串在指定字符串中的位置 4、str_replace():字符串替换 字符串与数组的转化函数 1、explode():字符串转化为数组 2、implo…

vue php 文件上传,使用vue.js和laravel上传文件

我尝试在vue.js和laravel中上传pdf文件&#xff0c;files_array是这样定义的:data(){return {formData: new Form ({files_array:,...这是一个文件选择函数:selectFile(e) {let pdfFile e.target.files[0];this.formData.files_array pdfFile;}上传功能:const header {Conten…

用webstorm自动编译less产出css和sourcemap

css产出sourcemap有什么用呢&#xff0c;可能大家要问这个问题了。 请移步这里 https://developers.google.com/chrome-developer-tools/docs/css-preprocessors?hlzh-CN 在chrome中我们通过sourcemap可以直接调试less源文件文件&#xff0c;这是一个非常强大的功能。 下面由我…

远近旋转球体

2019独角兽企业重金招聘Python工程师标准>>> static int day 20; void mydisplay(void) {int a clock();glEnable(GL_DEPTH_TEST);glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);//清空颜色缓存与深度缓存glMatrixMode(GL_PROJECTION);//接下来要进行的操作…

matlab里数组的赋值,arrays – MATLAB结构赋值数组

我有一系列结构.让我们说s(1).value,…,s(5).value.我有一个值向量,让我们说vals [1 2 3 4 5],我想分配给结构数组.所以用伪代码写我想要&#xff1a;s(:).value vals.如下所示,有一个已知的解决方案.但是真的不可能像在伪代码中那样在1行中进行这个赋值吗&#xff1f;% Vect…

Linux(CentOS)挂载NTFS格式的U盘、移动硬盘

以下操作均在root下执行的 1.U盘挂载 mkdir /mnt/usb //创建一个目录&#xff0c;用于挂载U盘 fdisk -l //查看系统中挂载的U盘&#xff0c;若系统有一块硬盘sdb1 代表你的U盘&#xff0c;/dev/sdb1表明机 器已识别U盘&#xff0c; mount /dev/sdb1 /mnt/usb //把U盘/dev/sdb1挂…

iOS开发UI篇—CALayer简介

一、简单介绍在iOS中&#xff0c;你能看得见摸得着的东西基本上都是UIView&#xff0c;比如一个按钮、一个文本标签、一个文本输入框、一个图标等等&#xff0c;这些都是UIView。 其实UIView之所以能显示在屏幕上&#xff0c;完全是因为它内部的一个图层&#xff0c;在创建UIVi…

EXCEL使用技巧

Excel: 1、隔行变色|菜单->条件格式->其它规则->使用公式->"MOD(ROW(),2)0" 2、查找包含特定字符的单元格&#xff0c;并替换整个单元格 Sub FindAndReplace()Dim i As IntegerWith Range("G23:G25") 指定替换范围For i 1 To .Cells.CountIf …

Cisco 3560 配置DHCP Relay实例

网络环境&#xff1a;一台3560交换机&#xff0c;划分三个vlan,vlan2为服务器所在网络&#xff0c;命名为server,IP地址段为192.168.2.0,子网掩码:255.255.255.0,网关:192.168.2.1,域服务器为windows2000advanceserver,同时兼作DHCP服务器&#xff0c;DNS服务器&#xff0c;IP地…

php 多进程 常驻内存,PHP 多进程与信号中断实现多任务常驻内存管理 [Master/Worker 模型]...

本文章基于pcntl扩展做的多进程测试。进程调度策略父子进程的调度由操作系统来负责&#xff0c;具体先调度子进程还是父进程由系统的调度算法决定&#xff0c;当然可以在父进程加上延时或是调用进程回收函数pcntl_wait可以先让子进程先运行&#xff0c;进程回收的目的是释放进程…

LINQ to JavaScript

JSLINQ 是一个将LINQ对象转化为JavaScript对象的工具 。它是构建在JavaScript的数组对象的基础上进行转换的&#xff0c;如果您使用的是一个数组&#xff0c;你可以使用LINQ到javascript 。 示例&#xff1a; var myList [ {FirstName:"Chris",LastName:…

php 可维护性的代码,软件的可复用性和可维护性

一、软件的可复用性可复用性(Reuseability)复用又叫重用&#xff0c;是重复使用的意思。一般软件的复用率并不高&#xff0c;尤其在国内。复用的好处可以得到 较高的生产效率以及随之而来的成本降低、较高的软件质量(错误可以更快的被纠正)以及 恰当的使用复用可以改善系统的可…

C# 多个线程一直跑着While(true)

在使用多线程的时候&#xff0c;开了多个线程一直在While(true)&#xff0c;会造成CPU占用很高。这时候要在线程内加入一句Thread.Sleep(1)&#xff0c;让他稍微睡一下。就不会消耗那么多CPU了。 代码&#xff1a; 1 Thread dataThread new Thread(delegate()2 {3…

RPG的错排

RPG的错排 Time Limit : 1000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Submission(s) : 25 Accepted Submission(s) : 14 Problem Description今年暑假杭电ACM集训队第一次组成女生队,其中有一队叫RPG,但做为集训队成员之一的野骆驼竟然不知道…