[POJ 1787]Charlie's Change (动态规划)
题目链接:http://poj.org/problem?id=1787
题意:有4种货币分别是1元,5元,10元,20元。现在告诉你这四种货币分别有多少个,问你正好凑出P元钱最多可以用多少货币。每种货币要用多少钱。
据说此题有完全背包的写法。。
我是按照多重背包写的,速度也不是很慢。
然后记录了下前驱。
刚开始全都写挫了。。虽然现在也很挫。。
凑合着看吧 --
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <map>
#include <iterator>
#include <vector>
using namespace std;
typedef long long LL; const int INF = ; int P,c[],v[];
int dp[];
int fa[][]; int main(){
v[] = ;
v[] = ;
v[] = ;
v[] = ;
while(){
scanf("%d",&P);
for(int i=;i<=;i++) scanf("%d",&c[i]);
if( P== && c[]==&&c[]==&&c[]==&&c[]==){
break;
}
for(int j=;j<;j++){
dp[j] = -INF;
}
dp[] = ;
memset(fa,,sizeof(fa));
for(int i=;i<=;i++){
if( c[i]*v[i]>P ){
for(int j=v[i];j<=P;j++) {
if( dp[j]<dp[j-v[i]]+){
dp[j] = dp[j-v[i]]+;
if( dp[j]<= ) continue;
for(int k=;k<=;k++){
if( k==i ) fa[j][k] = fa[j-v[i]][k] + ;
else fa[j][k] = fa[j-v[i]][k];
}
}
// dp[j] = max(dp[j],dp[j-v[i]]+1);
}
} else {
int k = ;
while( k<c[i] ){
for(int j=P;j>=v[i]*k;j--){
if( dp[j]<dp[j-v[i]*k]+k ){
dp[j] = dp[j-v[i]*k]+k ;
// if( dp[j]>=0 ) fa[j][i] = fa[j-v[i]*k][i] + k;
if( dp[j] <= ) continue;
for(int e=;e<=;e++){
if( e==i ) fa[j][e] = fa[j-v[i]*k][e] + k;
else fa[j][e] = fa[j-v[i]*k][e];
}
}
// dp[j] = max(dp[j],dp[j-v[i]*k]+k);
}
c[i] -= k;
k <<= ;
}
if( c[i]<= ) continue;
for(int j=P;j>=v[i]*c[i];j--){
if( dp[j]<dp[j-v[i]*c[i]] + c[i] ){
dp[j] = dp[j-v[i]*c[i]] + c[i];
if( dp[j] <= ) continue;
for(int e=;e<=;e++){
if( e==i ) fa[j][e] = fa[j-v[i]*c[i]][e] + c[i];
else fa[j][e] = fa[j-v[i]*c[i]][e];
}
}
// dp[j] = max(dp[j],dp[j-v[i]*c[i]] + c[i] );
}
}
}
if( dp[P] <= ) puts("Charlie cannot buy coffee.");
else printf("Throw in %d cents, %d nickels, %d dimes, and %d quarters.\n",fa[P][],fa[P][],fa[P][],fa[P][]);
}
return ;
}
[POJ 1787]Charlie's Change (动态规划)的更多相关文章
- poj 1787 Charlie's Change (多重背包可作完全背包)
Charlie's Change Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 3792 Accepted: 1144 ...
- POJ 1787 Charlie's Change (完全背包/多重背包,输出方案的物品个数)
网上说是多重背包,因为要输出方案,还要记录下路径,百度一下题解就可以. 自己做的时候,还没了解过多重背包,该题直接往完全背包思考了.咖啡的钱看作总的背包容量,1.5.10.25分别代表四种物品的重量, ...
- poj 1787 Charlie's Change
// 题意 给定一个数p,要求用四种币值为1,5,10,25的硬币拼成p,并且硬币数要最多,如果无解输出"Charlie cannot buy coffee.",1<=p&l ...
- POJ 1787 Charlie's Change
多重背包 可行性+路径记录 题意是说你要用很多其它的零钱去买咖啡.最后输出你分别要用的 1,5 ,10 .25 的钱的数量. 多重背包二进制分解.然后记录下 这个状态.最后逆向推就可以. #inclu ...
- poj 1787 背包+记录路径
http://poj.org/problem?id=1787 Charlie's Change Time Limit: 1000MS Memory Limit: 30000K Total Subm ...
- (多重背包+记录路径)Charlie's Change (poj 1787)
http://poj.org/problem?id=1787 描述 Charlie is a driver of Advanced Cargo Movement, Ltd. Charlie dri ...
- Charlie's Change POJ - 1787
Time limit 1000 ms Memory limit 30000 kB description Charlie is a driver of Advanced Cargo Movement, ...
- 专题复习--背包问题+例题(HDU 2602 、POJ 2063、 POJ 1787、 UVA 674 、UVA 147)
*注 虽然没什么人看我的博客但我还是要认认真真写给自己看 背包问题应用场景给定 n 种物品和一个背包.物品 i 的重量是 w i ,其价值为 v i ,背包的容量为C.应该如何选择装入背包中的物品,使 ...
- Charlie's Change(完全背包+路径记忆)
Charlie's Change Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 3176 Accepted: 913 D ...
随机推荐
- Java语言编码规范(Java Code Conventions)
Java语言编码规范(Java Code Conventions) 名称 Java语言编码规范(Java Code Conventions) 译者 晨光(Morning) 简介 本文档讲述了Java语 ...
- 【mysql】MySQL存储IP地址
为什么要问如何存储IP 首先就来阐明一下部分人得反问:为什么要问IP得怎样存,直接varchar类型不就得了吗? 其实做任何程序设计都要在功能实现的基础上最大限度的优化性能.而数据库设计是程序设计中不 ...
- 【mysql】mysql分表和表分区详解
为什么要分表和分区? 日常开发中我们经常会遇到大表的情况,所谓的大表是指存储了百万级乃至千万级条记录的表.这样的表过于庞大,导致数据库在查询和插入的时候耗时太长,性能低下,如果涉及联合查询的情况,性能 ...
- jquery.find()
http://www.365mini.com/page/jquery-find.htm
- openstack(liberty):部署实验平台(二,简单版本软件安装 part2)
继续前面的part1,将后续的compute以及network部分的安装过程记录完毕! 首先说说compute部分nova的安装. n1.准备工作.创建数据库,配置权限!(密码依旧是openstack ...
- 修改webftp,在线文件管理
项目中要添加一个文件管理功能,允许用户维护自己的静态HTML文件. 在网上找了一个现成的在线PHP文件管理工具:webftp 下载地址:http://down.chinaz.com/soft/3067 ...
- JDBC的URL设置allowMultiQueries的原因
如下的一个普通JDBC示例: String user ="root";String password = "root";String url = "j ...
- MySQL使用Union创建视图报错
mysql> select * from test_main; +----+-------+ | id | value | +----+-------+ | 1 | ONE | | 2 ...
- Maven错误在这里看【项目无法成功编译由于maven未成功下载依赖导致】
- 推荐一个css帮助手册的版本 同时提供chm和在线
版本保持更新 目录分类妥当 查阅很方便 就是习惯了jquery那种风格,略有不适应. 包括最新css3的内容 网址: http://css.doyoe.com/ chm下载地址: http://css ...