HDU 2844 Coins 【多重背包】(模板)
题目大意:
一位同学想要买手表,他有n种硬币,每种硬币已知有num[i]个。已知手表的价钱最多m元,问她用这些钱能够凑出多少种价格来买手表。
解题分析:
很明显,这是一道多重背包的问题,下面是用二进制拆分的多重背包的万能模板。
#include <bits/stdc++.h>
using namespace std; const int INF = 1e9;
int n,m,val[],cnt[],dp[int(1e5+)]; void OneZeroPack(int m,int v,int value){ //01背包
for(int i=m;i>=v;i--)
dp[i]=max(dp[i],dp[i-v]+value);
} void CompletePack(int m,int v,int value){ //完全背包
for(int i=v;i<=m;i++)
dp[i]=max(dp[i],dp[i-v]+value);
} void MultiplePack(int m,int v,int value,int num){
if(v*num>=m) { CompletePack(m,v,value); return; } //如果这些物品总体积大于容量,当成完全背包计算
for(int k=;k<=num;k<<=){ //否则当成01背包,但是对这些物品进行二进制拆分
OneZeroPack(m,v*k,value*k);
num-=k;
}
if(num)OneZeroPack(m,v*num,value*num);
} int main(){
while(~scanf("%d%d",&n,&m),n||m){
for(int i=;i<=m;i++)dp[i]=-INF;
for(int i=;i<n;i++)scanf("%d",&val[i]);
for(int i=;i<n;i++)scanf("%d",&cnt[i]);
dp[]=;
for(int i=;i<n;i++)
MultiplePack(m,val[i],val[i],cnt[i]);
int ans=;
for(int i=;i<=m;i++)
if(dp[i]>)ans++;
printf("%d\n",ans);
}
}
另一种方法:
#include <cstdio>
#include <cstring> bool dp[];
int use[];//i元钱时某种钱用的次数
int n, m;
int val[], num[]; void solve()
{
memset(dp, , sizeof(dp));
dp[] = ;
int count = ;
for (int i = ; i <= n; i++) //此题解法就是,现将每一个物品*(1~num[i])所能达到的价格都标记
{
memset(use, , sizeof(use)); //每次初始化第i种钱用了0次
for (int j = val[i]; j <= m; j++) //顺序枚举钱数
{
if (dp[j - val[i]] && !dp[j] && use[j - val[i]] < num[i])
{
dp[j] = ; //如果钱数为i的情况记录过了,那么就标记,防止count重复+1
use[j] = use[j - val[i]] + ;//到达j元用的i种钱的次数是到达 j-val[i]元用的次数加1
count++;
}
}
}
printf("%d\n", count);
} int main()
{
while (~scanf("%d %d", &n, &m),n||m)
{
for (int i = ; i <= n; i++)
scanf("%d", &val[i]);
for (int i = ; i <= n; i++)
scanf("%d", &num[i]); solve();
}
return ;
}
HDU 2844 Coins 【多重背包】(模板)的更多相关文章
- hdu 2844 Coins (多重背包+二进制优化)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2844 思路:多重背包 , dp[i] ,容量为i的背包最多能凑到多少容量,如果dp[i] = i,那么代表 ...
- HDu -2844 Coins多重背包
这道题是典型的多重背包的题目,也是最基础的多重背包的题目 题目大意:给定n和m, 其中n为有多少中钱币, m为背包的容量,让你求出在1 - m 之间有多少种价钱的组合,由于这道题价值和重量相等,所以就 ...
- HDU - 2844 Coins(多重背包+完全背包)
题意 给n个币的价值和其数量,问能组合成\(1-m\)中多少个不同的值. 分析 对\(c[i]*a[i]>=m\)的币,相当于完全背包:\(c[i]*a[i]<m\)的币则是多重背包,考虑 ...
- hdu 2844 Coins 多重背包(模板) *
Coins Time Limit: 2000/1 ...
- HDU 2844 Coins (多重背包计数 空间换时间)
Coins Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- hdu 2844 coins(多重背包 二进制拆分法)
Problem Description Whuacmers use coins.They have coins of value A1,A2,A3...An Silverland dollar. On ...
- HDU 2844 Coin 多重背包
Coins Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- 背包系列练习及总结(hud 2602 && hdu 2844 Coins && hdu 2159 && poj 1170 Shopping Offers && hdu 3092 Least common multiple && poj 1015 Jury Compromise)
作为一个oier,以及大学acm党背包是必不可少的一部分.好久没做背包类动规了.久违地练习下-.- dd__engi的背包九讲:http://love-oriented.com/pack/ 鸣谢htt ...
- HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化)
HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化) 题意分析 先把每种硬币按照二进制拆分好,然后做01背包即可.需要注意的是本题只需要求解可以凑出几种金钱的价格,而不需要输出种数 ...
- HDU 2191 珍惜现在,感恩生活(多重背包模板题)
多重背包模板题 #include<iostream> #include<cstring> #include<algorithm> using namespace s ...
随机推荐
- saltstack系列~第二篇
一 简介:今天咱们来继续学习saltstack 二 命名和分组 1 命名规则 1 ID构成 机房-DB类型-角色(主/从)-IP地址 2 分组构成 分为master slave两组即可 2 分组规则 ...
- 解决:[DCC Fatal Error] **.dpk : E2202 Required package '***' not found
//[DCC Fatal Error] **.dpk : E2202 Required package '***' not found 意思是:[DCC致命错误] *:e2202需包***没有发现 D ...
- weblogic对JSP预编译、weblogic读取JSP编译后的class文件、ant中weblogic.jspc预编译JSP
我们都知道在weblogic中JSP是每次第一次访问的时候才会编译,这就造成第一次访问某个JSP的时候性能下降,有时候我们也希望JSP被编译成class然后打包在jar中实现隐藏JSP的功能,下面介绍 ...
- C# 无法识别的消息版本。
问题:最近跟OA的java项目做审核接口,调用接口时提示"无法识别的消息版本.“ 解决:一直以为是协议不兼容,查了半天,最终发现是这个项目.net framework版本太低,升级为高版本即 ...
- 【转】inotify+rsync实现实时同步
[转]inotify+rsync实现实时同步 1.1 什么是实时同步:如何实现实时同步 要利用监控服务(inotify),监控同步数据服务器目录中信息的变化 发现目录中数据产生变化,就利用rsync服 ...
- UML和模式应用4:初始阶段(6)--迭代方法中如何使用用例
1.前言 用例是UP和其他众多迭代方法的核心.UP提倡用例驱动开发. 2. 迭代方法中如何使用用例 功能需求首先定义在用例中 用例是迭代计划的重要部分,迭代是通过选择一些用例场景或整个用例来定义的 用 ...
- Linux的capability深入分析(1)【转】
转自:https://blog.csdn.net/wangpengqi/article/details/9821227 一)概述: )从2.1版开始,Linux内核有了能力(capability)的概 ...
- word文档里打不开公式 打开后都是方框
因为系统缺少一种字体,只要到网络上下载或到其他计算机中复制一种文件名为“symbol.ttf”的字体文件来安装上,就可以了.参考资料:Office之家 http://www.officejia.com ...
- Raw Socket vs Stream Socket vs datagram socket,原始套接字与流式套接字与数据报套接字
https://opensourceforu.com/2015/03/a-guide-to-using-raw-sockets/ In this tutorial, lets take a look ...
- springboot系列十一、redisTemplate和stringRedisTemplate对比、redisTemplate几种序列化方式比较
一.redisTemplate和stringRedisTemplate对比 RedisTemplate看这个类的名字后缀是Template,如果了解过Spring如何连接关系型数据库的,大概不会难猜出 ...