背包问题——第一篇

一,01背包

最简单也是最经典的背包问题。
在这里插入图片描述
首先我们知道背包问题是一种d问题,最重要的就是要去找到他的状态转移方程。而在01背包中转移方程就比较简单了,这里用一个二维数组进行标表示。
ans[i][j]=max(ans[i-1][j],ans[i-1][j-v[i]+w[i]);
在这里i表示的是第几件物品,j表示的是背包当前课装下的最大体积,
0 1 就是有两种选择:
不装第i件物品,此时的状态就是,装上一件物品的相同体积的状态。
装第i件物品,此时还要考虑当前的背包容量能不能装得下,如果可以,就装下,此时的价值变成了,ans[i-1][j-v[i]]+w[i],

因为我们要的是在背包中尽可能的装入跟多的价值,所以这里就要取一个max值

//没有任何优化的版本。 
#include<iostream> 
#include<algorithm>
#include<cstring>
#define maxn 1005
int ans[maxn][maxn];
int  v[maxn],w[maxn];
using namespace std;
int main() {int n,m;while(cin>>n>>m) {memset(ans,0,sizeof(ans));for(int i=1;i<=n;i++)cin>>v[i]>>w[i];ans[0][0]=0;for(int i=1;i<=n;i++) {for(int j=0;j<=m;j++) {ans[i][j]=ans[i-1][j];if(j>=v[i])ans[i][j]=max(ans[i][j],ans[i-1][j-v[i]]+w[i]);}}cout<<ans[n][m]<<endl;}return 0;
}

这是没有任何优化的版本,也是最好理解背包问题的状态转移方程的代码。
接下来我们对空间进行优化。

//空间优化版本。
#include<iostream>
#include<cstring>
#define maxn 1005
int ans[maxn];
using namespace std;
int main() {int n,m;while(cin>>n>>m) {memset(ans,0,sizeof(ans));while(n--) {int v,w;cin>>v>>w;for(int i=m;i>=v;i--) {//注意在这层循环一定是从大到小,才能保证物品最多只选用一次,ans[i]=max(ans[i],ans[i-v]+w);}}cout<<ans[m]<<endl;}return 0;
} 

二、完全背包。

在这里插入图片描述
这里我们可以对上面的0 1 背包一样,对于每种可以当成是0 1背包的特殊情况,只不过每件物品是一样的。
但是在这里要注意的是,共有n次0 1背包循环,

#include<iostream>
#include<cstring>
#define maxn 1005
int ans[maxn];
using namespace std;
int main()
{int n,m;while(cin>>n>>m) {memset(ans,0,sizeof(ans));for(int i=0;i<n;i++) {int v,w;cin>>v>>w;for (int j=v;j<=m;j++)//这里刚好跟上面相反,物品能多次选择ans[j]=max(ans[j],ans[j-v]+w);}cout<<ans[m]<<endl;}return 0;} 

三、多重背包。

在这里插入图片描述
这一道题当我们理解了前面两道题目的是后发现并不难,只要在0 1背包加一重循环来枚举数量。
于是我们有了下面的代码。

//没有任何优化的版本。 
#include<iostream>
#include<cstring>
#define maxn 1005
int ans[maxn]; 
using namespace std;
int main() {int n,m;while(cin>>n>>m) {memset(ans,0,sizeof(ans));while(n--) {int v,w,s;cin>>v>>w>>s;for(int i=1;i<=s;i++) {for(int j=m;j>=i*v;j--) {ans[j]=max(ans[j],ans[j-i*v]+i*w);}}}cout<<ans[m]<<endl;}return 0;
}

但是我们仔细想一想,这里的时间复杂度,nVs 已经到了1e9了,这里显然会超时,想一想我们有没有什么办法来组合每一种物品的数量,
比如说15 我们可以变成,1,2,4,8的组合,而且1~15之间的任意数都可以是这几个数的组合,于是我们想到了用二进制来拆分优化数,这里的s就可以降到log2s了,

//二进制优化方法。
#include<iostream>
#include<algorithm>
#include<cstring>
#include<vector>
#define maxn 100000
int ans[maxn];
struct each {int v,w;
};
using namespace std;
int main()
{int n,m;vector<each>a;while(cin>>n>>m) {memset(ans,0,sizeof(ans));a.clear();for(int i=1;i<=n;i++) {int v1,w1,s;cin>>v1>>w1>>s;for(int i=1;i<=s;i*=2) {s-=i;a.push_back({i*v1,i*w1});}if(s>0)a.push_back({s*v1,s*w1});}for(int i=0;i<a.size();i++) {for(int j=m;j>=a[i].v;j--)ans[j]=max(ans[j],ans[j-a[i].v]+a[i].w);}cout<<ans[m]<<endl;}return 0;
}

当然了对于数据没有这么大的多重背包还是可以用第一个代码来写的
其实这里还有一个单调队列优化的,但是我水平有限就,没给出代码,了,有兴趣可以自己去找一下代码,

四、混合背包。

在这里插入图片描述
这组样例的答案是8


其实这里就是前三种问题的汇总,我们可以在输入的时候进行处理进行分类,下面是汇总了目前我会的上面的几种方法的最优解

//二进制优化版本,加多混合背包。
#include<iostream> 
#include<cstring>
#include<vector>
#include<algorithm>
#define maxn 10005
int ans[maxn];
using namespace std;
struct each {int v,w;
};
int main() {int n,m;vector<each>a;while(cin>>n>>m) {a.clear();memset(ans,0,sizeof(ans));while(n--) {int v1,w1,s;cin>>v1>>w1>>s;if(s==-1) {for(int j=m;j>=v1;j--)ans[j]=max(ans[j],ans[j-v1]+w1);}else if(s==0) {for(int j=v1;j<=m;j++)ans[j]=max(ans[j],ans[j-v1]+w1);}else {for(int i=1;i<=s;i*=2) {s-=i;a.push_back({i*v1,i*w1});}if(s>0)a.push_back({s*v1,s*w1});}	}int longs=a.size();for(int i=0;i<longs;i++)for(int j=m;j>=a[i].v;j--)ans[j]=max(ans[j],ans[j-a[i].v]+a[i].w);cout<<ans[m]<<endl;	}return 0;
}

五、分组背包。

在这里插入图片描述
这里我们又可以吧分组背包看成是多重背包的一个特殊例子,每组个数有限制,但是只能取一个

#include<iostream>
#include<cstring>
#define maxn 105
int ans[maxn],v[maxn],w[maxn]; 
using namespace std;
int main() {int n,m;while(cin>>n>>m) {memset(ans,0,sizeof(ans));while(n--) {int x;cin>>x;for(int i=0;i<x;i++)	cin>>v[i]>>w[i];for(int i=m;i>0;i--)for(int j=0;j<x;j++)if(i>=v[j])	ans[i]=max(ans[i],ans[i-v[j]]+w[j]);}cout<<ans[m]<<endl;}return 0;
}

剩下还有四个背包以后再更吧,就先写到这。

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

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

相关文章

小白开学Asp.Net Core 《十》

小白开学Asp.Net Core 《十》 — — Session、Cookie、Cache&#xff08;老生常谈&#xff09;一、背景在常谈Session和Cookie之前我们先来简单的了解下Http&#xff08;可以说这是必须的&#xff0c;默认大家都了解&#xff09;总结一句话&#xff1a;HTTP是一种无状态的协议&…

P3935 Calculating 整除分块

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 我们设s(x)∑i1nf(x)s(x)\sum_{i1}^nf(x)s(x)∑i1n​f(x)&#xff0c;那么答案就是s(r)−s(l−1)s(r)-s(l-1)s(r)−s(l−1)。 容易发现&#xff0c;我们要求的f(x)f(x)f(x)实际上就是xxx的…

Sticks-hdu-1455深度搜索dfs

Sticks 题目传送门。 题目大意是&#xff0c;给你一个数字n代表总共的棍子数量&#xff0c;要做的就是&#xff0c;把这几根棍子拼成长度相同的棍子&#xff0c;并且让所拼成的棍子的长度尽可能地小&#xff0c;也就是拼成的棍子的数量尽可能的多。 在这里很简单的想到要给棍…

gRPC in ASP.NET Core 3.0 -- Protocol Buffer(1)

开发环境&#xff1a;IDE: VSCodeVSCode的扩展插件&#xff1a;vscode-proto3和Clang-Format这两个扩展Windows还需要安装Clang&#xff0c;Windows 64位系统的地址如下&#xff1a;Clang for Windows (64-bit)(http://llvm.org/releases/3.7.0/LLVM-3.7.0-win64.exe)&#xff…

[蓝桥杯2016初赛]方格填数

正如题目&#xff0c;我们要保证相邻的数不相连就行了&#xff0c;一共要填十个数。 下面是我的思路&#xff0c;供大家参考一下&#xff0c; 我把上面的各子放进了这个5*6的矩形&#xff0c;其中标记1–10的分别是要填数的各格子&#xff0c;一开始我先初始化这个二维数组为全…

2021牛客暑期多校训练营7 xay loves monotonicity 线段树区间合并

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 题面挺绕口的&#xff0c;还是看原题比较好。 大概的意思就是让你从给定的区间中选择一个以左端点为起点的一个上升子序列&#xff0c;让后将这些下标存下来&#xff0c;在bbb中将这些位置拿出来后&#xff…

容器化单页面应用中Nginx反向代理与Kubernetes部署

在《容器化单页面应用中RESTful API的访问》一文中&#xff0c;我介绍了一个在容器化环境中单页面应用访问后端服务的完整案例。这里我将继续使用这个案例&#xff0c;介绍一下容器化单页面应用部署的另一个场景&#xff1a;将Nginx的职责独立出来。注&#xff1a;这里单页面应…

[蓝桥杯2019初赛]迷宫-DFS、BFS两种方法

迷宫问题的最短路&#xff0c;加最小字典序 迷宫文件maze.txt传送门 作者写的2019年B组蓝桥杯解集 . . . DFS的版本 #include<iostream> #include<cstring> using namespace std; const int ax[4]{0,0,1,-1}; const int ay[4]{1,-1,0,0}; const char dir[5]{R,L…

2021牛客暑期多校训练营7 xay loves trees dfs序 + 主席树

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两棵树&#xff0c;让你在第一棵树选一条最长的深度递增的链&#xff0c;链上每一个点在第二棵树上都不互为祖先。 n≤3e5n\le3e5n≤3e5 思路&#xff1a; 之前做过差不多的题传送门。 之前哪个题是不…

xxl-job dotnet core executor执行器开源

DotXxlJob[(github)https://github.com/xuanye/DotXxlJob][https://github.com/xuanye/DotXxlJob] xxl-job的dotnet core 执行器实现&#xff0c;支持XXL-JOB 2.01 XXL-JOB概述[XXL-JOB][1]是一个轻量级分布式任务调度平台&#xff0c;其核心设计目标是开发迅速、学习简单、轻量…

2019年第十届蓝桥杯 C / C ++省赛 B 组真题题解

A: 组队 输入数据 编号 号位1 2 3 4 51 97 90 0 0 0 2 92 85 96 0 0 3 0 0 0 0 93 4 0 0 0 80 86 5 89 83 97 0 0 6 82 86 0 0 0 7 0 0 0 87 90 8 0 97 96 0 0 9 0 0 89 0 0 10 95 99 0 0 0 11 0 0 96 97 0 12 0 0 0 93 98 13 94 91 0 0 0 14 0 83 87 0 0 15 …

HDU - 7054 Yiwen with Formula 分治拆位FFT + dp + 费马小定理降幂

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 求aaa的所有子序列的和的乘积。 思路&#xff1a; 看到suma≤1e5sum_a\le1e5suma​≤1e5&#xff0c;这应该会给我们提示&#xff0c;但是我没看到。 我们可以记cntxcnt_xcntx​表示和为xxx的子序列有cnt…

使用Redis创建分布式锁

点击上方蓝色字关注我们~在本文中&#xff0c;我们将讨论如何在.NET Core中使用Redis创建分布式锁。当我们构建分布式系统时&#xff0c;我们将面临多个进程一起处理共享资源&#xff0c;由于其中只有一个可以一次使用共享资源&#xff0c;因此会导致一些意外问题&#xff01;我…

ASP.NET Core Web Api之JWT VS Session VS Cookie(二)

本文我们来探讨下JWT VS Session的问题&#xff0c;我们可直接抛出问题&#xff1a;使用客户端存储的JWT比服务端维持Session更好吗&#xff1f; 既然要比较JWT VS Session&#xff0c;那我们就得知道为何需要JWT和Session&#xff0c;它们共同是为了解决什么问题呢&#xff1f…

P4721 【模板】分治 FFT

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 写一下式子&#xff0c;发现每个fif_ifi​只有左边的fff对他有影响&#xff0c;所以考虑分治FFTFFTFFT来解决这个问题。 先递归左边&#xff0c;让后计算对右边贡献&#xff0c;再递归右边…

程序员生活之路--来自程序员爸爸的一封信

亲爱的孩子&#xff1a;当你看到爸爸这封信的时候&#xff0c;说明你已经长大了或者已经会玩微信公众号了&#xff0c;当然爸爸还是希望你长大了&#xff0c;并不希望你那么小就天天抱着手机刷微信。我写这个文章的时候正直盛夏&#xff0c;现在外边正是37度的高温&#xff0c;…

C#上位机与欧姆龙PLC的通信05---- HostLink协议

1、介绍 Hostlink协议是欧姆龙PLC与上位机链接的公开协议。上位机通过发送Hostlink命令&#xff0c;可以对PLC进行I/O读写、可以对PLC进行I/O读写、改变操作模式、强制置位/复位等操作。由于是公开协议&#xff0c;即便是非欧姆龙的上位设备&#xff08;软件&#xff09;&…

Codeforces Round #737 (Div. 2) D. Ezzat and Grid 线段树动态开点

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 比较套路的一个题&#xff0c;我们维护一个dp[i]dp[i]dp[i]表示到了第iii行能保留的区间最多是多少。 转移比较明显&#xff1a;dp[i]max(dp[j])dp[i]max(dp[j])dp[i]max(dp[j]) 其中jjj能…

从零开始实现ASP.NET Core MVC的插件式开发(三) - 如何在运行时启用组件

标题&#xff1a;从零开始实现ASP.NET Core MVC的插件式开发(三) - 如何在运行时启用组件 作者&#xff1a;Lamond Lu地址&#xff1a;https://www.cnblogs.com/lwqlun/p/11260750.html源代码&#xff1a;https://github.com/lamondlu/DynamicPlugins前情回顾•从零开始实现ASP…

SP1043 GSS1 - Can you answer these queries I 猫树

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 猫树是一种可以O(nlogn)O(nlogn)O(nlogn)预处理&#xff0c;O(1)O(1)O(1)查询的数据结构。预处理的信息应该满足可合并的性质&#xff0c;与线段树pushuppushuppushup的原理相同&#xff0…