HDU3535 AreYouBusy 混合背包
题目大意
给出几组物品的体积和价值,每组分为三种:0.组内物品至少选一个;1.组内物品最多选一个;2.组内物品任意选。给出背包容量,求所能得到的最大价值。
注意
- 仔细审题,把样例好好看完了再答题,否则非常浪费时间!
混合背包
定义DP(i,j)为轮到第1~i组背包内物品总体积严格为j时所能得到的最大价值,实现用滚动数组。(以下i或i-1后都&1)
种类2
把当前的DP(i,..)当作一个关于背包的一维覆盖数组(因为是关于整个背包的数组,所以要把DP(i-1,...)的值拷贝到一维覆盖数组中),对该组内所有物品在背包内进行01背包即可。递归式DP(k,j)=max{DP(k-1, j), DP(k-1, j-v[k])+w[k]}.
注意
- 因为DP在一个一维覆盖数组内进行,所以DP内的第一个参数永远是i。
种类1
在整个背包内进行一遍分组背包即可。递归式为DP(i,j)=max{DP(i-1, j), max{DP(i-1,j-v[i][k])+W[i][k] | k属于组i}}
注意
- DP中第一个参数的值总是i-1。
种类0
01背包中,如果DP(i-1, j)>DP(k=1, j-v[k])+w[k]且每个DP(k-1, j)>DP(k,j-v[k]+w[k])可能会导致该组的物品一个都不选,但是DP值小一点不要求最大可能也能满足题意。此时就要对每一个k提供几个总价值小一点的选择,包括k-1所代表的稍小值(规定k-1的较小值是1~k-1中较小值中最大的),或不要k-1等物品,直接在i-1组放入k所代表的较小值(两个较小值不一定谁大呢)。
对于每个物品k,三种操作:选:1.在k之前的物品的基础上放入k,2.在i-1组内的基础上放入k。3.不选(k以前物品选出了一个则有解,否则再也没办法有解了)
即使不存在一开始所说的情况,1,3也是标准的01背包。以上取最大值即可。
注意
- 一开始数组是清空的。
注意
- 只在一开始对DP[0][0]设为0,其余设为-INF。对于每个组不要设置DP[i][0]。
- 循环体积要一直循环到0,因为有体积为0的物体。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cassert>
using namespace std; const int MAX_GROUP = 110, MAX_V = 110, MAX_EACH_OBJ = 100, MAX_TYPE = 3;
int V[MAX_GROUP][MAX_EACH_OBJ], W[MAX_GROUP][MAX_EACH_OBJ], Type[MAX_GROUP], ObjCnt[MAX_GROUP];
int totGroup, totV; int Proceed()
{
static int DP[2][MAX_V];
memset(DP, 0xcf, sizeof(DP));
DP[0][0] = 0;
for (int i = 1; i <= totGroup; i++)
{
memset(DP[i & 1], 0xcf, sizeof(DP[i & 1]));
switch (Type[i])
{
case 0://至少选一个
for (int k = 1; k <= ObjCnt[i]; k++)
{
for (int j = totV; j >= V[i][k]; j--)
{
DP[i & 1][j] = max(DP[i & 1][j], DP[i & 1][j - V[i][k]] + W[i][k]);
DP[i & 1][j] = max(DP[i & 1][j], DP[(i - 1) & 1][j - V[i][k]] + W[i][k]);
}
}
break;
case 1://最多选一个
memcpy(DP[i & 1], DP[i - 1 & 1], sizeof(DP[i - 1 & 1]));
for (int j = totV; j >= 0; j--)
for (int k = 1; k <= ObjCnt[i]; k++)
if (j >= V[i][k])
DP[i & 1][j] = max(DP[i & 1][j], DP[i - 1 & 1][j - V[i][k]]+W[i][k]);
break;
case 2://随便
memcpy(DP[i & 1], DP[i - 1 & 1], sizeof(DP[i - 1 & 1]));
for (int k = 1; k <= ObjCnt[i]; k++)
for (int j = totV; j >= V[i][k]; j--)
DP[i & 1][j] = max(DP[i & 1][j], DP[i & 1][j - V[i][k]] + W[i][k]);
break;
default:
assert(0);
}
}
int ans = -1;
for (int j = 0; j <= totV; j++)
ans = max(ans, DP[totGroup&1][j]);
return ans;
} int main()
{
#ifdef _DEBUG
freopen("c:\\noi\\source\\input.txt", "r", stdin);
freopen("c:\\noi\\test\\output.txt", "w", stdout);
#endif
while (~scanf("%d%d", &totGroup, &totV))
{
for (int group = 1; group <= totGroup; group++)
{
scanf("%d%d", group + ObjCnt, group + Type);
for (int obj = 1; obj <= ObjCnt[group]; obj++)
scanf("%d%d", obj + V[group], obj + W[group]);
}
printf("%d\n", Proceed());
}
}
HDU3535 AreYouBusy 混合背包的更多相关文章
- HDU 3535 AreYouBusy(混合背包)
HDU3535 AreYouBusy(混合背包) http://acm.hdu.edu.cn/showproblem.php?pid=3535 题意: 给你n个工作集合,给你T的时间去做它们.给你m和 ...
- UESTC 424 AreYouBusy --混合背包
混合三种背包问题. 定义:dp[i][k]表示体积为k的时候,在前i堆里拿到的最大价值. 第一类,至少选一项,dp初值全赋为负无穷,这样才能保证不会出现都不选的情况.dp[i][k] = max(dp ...
- HDU 3535 AreYouBusy (混合背包)
题意:给你n组物品和自己有的价值s,每组有l个物品和有一种类型: 0:此组中最少选择一个 1:此组中最多选择一个 2:此组随便选 每种物品有两个值:是需要价值ci,可获得乐趣gi 问在满足条件的情况下 ...
- HDU 3535 分组混合背包
http://acm.hdu.edu.cn/showproblem.php?pid=3535 题意:有n组工作,T时间,每个工作组中有m个工作,改组分类是s,s是0是组内至少要做一件,是1时最多做一件 ...
- Codevs 3269 混合背包(二进制优化)
3269 混合背包 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 背包体积为V ,给出N个物品,每个物品占用体积为V ...
- HDU3535——AreYouBusy
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3535 题目意思:给出两个数n,T,分别表示有n个任务集合,T的总时间,对于每个任务集合有两个属性m和t ...
- codevs 3269 混合背包(复习混合背包)
传送门 [题目大意]给出物品的数量.-1为无限个. [思路]混合背包.... [code] #include<iostream> #include<cstdio> #inclu ...
- [codevs3269]混合背包
题目大意:一道混合背包模板. 解题思路:分三种情况讨论,01和完全没什么问题,多重背包需要把物品分成$\log W[i]$件,然后01即可,分成W[i]件01会TLE. 读优大法好! C++ Code ...
- CODE[VS] 3269 混合背包
3269 混合背包 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description 背包体积为V ,给出N ...
随机推荐
- Get 和 Post
理论: Http定义了与服务器交互的不同方法,最基本的方法有4种,分别是GET,POST,PUT,DELETE.URL全称是资源描述符,我们可以这样认为:一个URL地址,它用于描述一个网络上的资源,而 ...
- spring data jpa 、hibernate、jpa之间的关系
引用:http://blog.csdn.net/u014421556/article/details/52635000 hibernate作为JPA的实现. JPA规范与ORM框架之间的关系 ...
- Unity引擎GUI之Input Field
InputField 文本输入组件,本文练习InputField的属性及事件 一.属性 1 Interactable: 是否禁用 Transition:过渡方式 Normal Color 正常的未有任 ...
- SLAM:(编译ORB)fatal error LNK1181: 无法打开输入文件“libboost_mpi-vc110-mt-1_57.lib”
对于使用MD版本编译的ORB_SLAM,会用到MPI版本的Boost,需要自己编译,比较麻烦. 因此使用MT版本进行生成,暂时无法完成. 工程配置 发现添加库文件使用了:从父级或项目默认继承,默认包含 ...
- 在 ef 中执行 DbContext.Table.AddRange(Enitites).ToList() 会发生什么
在 ef 中执行 DbContext.Table.AddRange(Enitites).ToList() 会发生什么 昨天和朋友摸鱼,无意之间聊到了执行 DbContext.Table.AddRang ...
- (转)Redis研究(一)—简介
http://blog.csdn.net/wtyvhreal/article/details/41855327 Redis是一个开源的高性能键值对数据库.它通过提供多种键值数据类型来适应不同场景下的存 ...
- boost asio异步读写网络聊天程序客户端 实例详解
boost官方文档中聊天程序实例讲解 数据包格式chat_message.hpp <pre name="code" class="cpp">< ...
- 【udacity】机器学习-knn最近邻算法
Evernote Export 1.基于实例的学习介绍 不同级别的学习,去除所有的数据点(xi,yi),然后放入一个数据库中,下次直接提取数据 但是这样的实现方法将不能进行泛化,这种方式只能简单的 ...
- python 疑难杂症
1.getpass模块 :Pycharm不支持getpass模块,使用terminal可运行,但是getpass中文提示显示乱码?
- [kernel]----理解kswapd的低水位min_free_kbytes
1. min_free_kbytes 先看官方解释: This is used to force the Linux VM to keep a minimum number of kilobytes ...