HDU2844买表——多重背包初探
HDU2844买表多重背包问题
题目大意都不大好懂,是利用手头上的硬币看看能组合出多少种价格,也就是跑完背包,看看有多少背包符合要求
剩下的就是多重背包的问题了
1.第一个处理办法就是直接当01背包进行存储和处理
2.第二个处理办法就是扫描物品时,当这个物品和数量产生的总价格大于限制时,采用完全背包的方法往里放不大的时候就按01背包的方法放
因为对于每一件物品我们所考虑的问题就是,放不放和放多少的问题
其实这两个方法都一样,只不过第一个方法啊直观上的解法就是扩充数组而第二个的直观解法节约了空间
学习和理解以下代码的时候,我有两个地方不好懂
1.二进制压缩原理:
我们都知道背包是一层一层向上构建的
只要抓住 1 2 4 8 16 32 .... 2^n这些数字可以合成 1到2^(n-1)-1中任何数字
简单来说:基础是0,第一次我取一个,dp更新的也只是取 1 个的基础
第二次我取两个,dp数组更新的就会是1个,2 个和3 个(二的基础加一的基础)的基础了
以此类推为了防止越出基础范围,所以每次要减去k,看看k还能不能再增加~
2.第二个就是最后符合条件的为什么是大于等于0就可以
这里跟题目理解的有些关系,对于背包的每一个容量,都必须完全装满才可以
所以这也是为什么对dp数组初始化的时候只把基础dp[0]初始化为0,其余的都初始化为相对无穷小
这样才能层层递推,而且递推出来的都是装的满满的背包
例如输入
2 5
1 4 2 1
那么第一次更新为01背包,更新了数组dp[1]
第二次也是01,更新了数组dp[2]
第三次01,更新了dp[4]和dp[5]
#include <iostream>
#include <cstdio>
#include <string.h>
#define inf 0xffffff
using namespace std;
const int maxn = 1e6;
const int maxm = 200;
int a[maxm],c[maxm];
int dp[maxn];
void Zero_one_pack(int m,int v,int w)
{
for(int i = m;i >= v;i--)
dp[i] = max(dp[i],dp[i-v]+w);
// cout<<"dp2 = "<<dp[5]<<endl;
}
void Complete_pack(int m,int v,int w)
{
for(int i = v;i <= m;i++)
dp[i] = max(dp[i],dp[i-v]+w);
}
void multiplePack(int m,int v,int w,int num)
{
if(v * num >= m)
{
Complete_pack(m,v,w);
return;
}
int k = 1;
for(k;k <= num;k <<= 1)
{
Zero_one_pack(m,k*v,k*w);
num -= k;
}
if(num)
Zero_one_pack(m,num*v,num*w);
}
int main()
{
int n,m;
while(~scanf("%d %d",&n,&m))
{
if(n == 0 && m == 0)break;
for(int i = 0;i < n;i++)
scanf("%d",&a[i]);
for(int i = 0;i < n;i++)
scanf("%d",&c[i]);
for(int i = 1;i <= m;i++)
dp[i] = -inf;
//背包必须要装满,所以初始赋值为负无穷
//对0赋值为0,层层向上递推
dp[0] = 0;
for(int i = 0;i < n;i++)
{
multiplePack(m,a[i],a[i],c[i]);
}
int sum = 0;
for(int i = 1;i <= m;i++)
{
if(dp[i] > 0)
{
sum++;
}
}
cout<<sum<<endl;
}
return 0;
}
HDU2844买表——多重背包初探的更多相关文章
- HDU2844 Coins(多重背包)
多重背包就是每种物品有数量限制时求解最大价值. 如果一种物品数量和重量之积超过背包容量,可视为完全背包:其余情况通过二进制拆分,将几个数量的物品看成一个,转化为01背包求解. 按照这种思路代码是这样的 ...
- hdu2844(多重背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2844 题意:一位同学想要买手表,他有n种硬币,每种硬币已知有num[i]个.已知手表的价钱最多m元,问 ...
- HDU2844 Coins 多重背包
Coins Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- HDU-2844 Coins(多重背包)
Problem Description Whuacmers use coins.They have coins of value A1,A2,A3...An Silverland dollar. On ...
- hdu2844 & poj1742 Coin ---多重背包--两种方法
意甲冠军:你有N种硬币,每个价格值A[i],每个号码C[i],要求. 在不超过M如果是,我们用这些硬币,有多少种付款的情况下,.那是,:1,2,3,4,5,....,M这么多的情况下,,你可以用你的硬 ...
- 假期训练六(poj-1753,递归+hdu-2844,多重背包)
题目一:传送门 题意:有一个4*4的棋盘,每次翻转一个棋子和它的上下左右的四个棋子,判断翻转多少次之后可以变为纯色的棋盘. 思路:总共有C(0,16)+C(1,16)+C(2,16)+……+C(16, ...
- (混合背包 多重背包+完全背包)The Fewest Coins (poj 3260)
http://poj.org/problem?id=3260 Description Farmer John has gone to town to buy some farm supplies. ...
- hdu 2191 多重背包 悼念512汶川大地震遇难同胞——珍惜现在,感恩生活
http://acm.hdu.edu.cn/showproblem.php?pid=2191 New~ 欢迎“热爱编程”的高考少年——报考杭州电子科技大学计算机学院关于2015年杭电ACM暑期集训队的 ...
- --hdu 2191 悼念512汶川大地震遇难同胞——珍惜现在,感恩生活(多重背包)
解题思路: 多重背包:第 i 件物品有 j 个可用. 本题中 第 p[i] 类大米 有 c[i] 袋大米可买 ,故本题为多重背包. n(总钱数).m(种类) p[i] 单价 h[i] 重量 c[i] ...
随机推荐
- python使用sqlite
摘自python帮助文档 一.基本用法 import sqlite3 conn = sqlite3.connect('example.db')#conn = sqlite3.connect(':mem ...
- Centos7 上安装 FastDFS
1.安装gcc(编译时需要) FastDFS是C语言开发,安装FastDFS需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,需要安装gcc yum install -y gcc ...
- 三分钟分布式CAP理论
分布式系统架构理论,定义了三种指标,理论说我们最多只能满足两个. ## 分布式系统 首先我们这个理论所说的分布式系统,是指系统内会共享数据,互相有连接有交互,才能完成系统功能的的分布式系统.而这个理论 ...
- nodejs 开发服务端 child_process 调试方法(1)
由于最近正在做一个服务端项目,采用了nodejs引擎开发,主要是master-worker工作机制;主进程可以直接调试,但是子进程调试好像有点麻烦,我没有找到好的方法; worker这里,我分拆成了几 ...
- Vim中如何使用正则进行搜索
#set magic这句的作用在于将vim的正则打开. 这样就可以搜索了. 至于正则的相关的内容.在此抄一份.以免于下次自己还要去百度. 符号 匹配 . (dot) 任意单一字符 \d 任意一位数字 ...
- urllib和requests库
目录 1. Python3 使用urllib库请求网络 1.1 基于urllib库的GET请求 1.2 使用User-Agent伪装后请求网站 1.3 基于urllib库的POST请求,并用Cooki ...
- ListView item中有button或EditText时 点击事件失效问题的解决
加入:android:descendantFocusability="blocksDescendants" 代码如下: <LinearLayout xmlns:android ...
- mybatis-mysql类型映射
JDBC Type Java Type CHAR String VARCHAR String LONGVARCHAR String NUMERIC java.math.BigDecimal DECIM ...
- [C#.NET]最简单的实现文本框的水印效果
C#项目开发中在设计登录界面时,经常会遇到TextBox的水印提示要求.这里简单描述一下项目在实现水印提示的过程设置.如下图图1所示. 图1 窗体布局 一.窗体布局(如图1所示) 1. 在窗体中放 ...
- P3834 【模板】可持久化线段树 1(主席树)
#include <bits/stdc++.h> #define read read() #define up(i,l,r) for(int i = (l);i <= (r);i++ ...