题目链接: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 (动态规划)的更多相关文章

  1. poj 1787 Charlie's Change (多重背包可作完全背包)

    Charlie's Change Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 3792   Accepted: 1144 ...

  2. POJ 1787 Charlie's Change (完全背包/多重背包,输出方案的物品个数)

    网上说是多重背包,因为要输出方案,还要记录下路径,百度一下题解就可以. 自己做的时候,还没了解过多重背包,该题直接往完全背包思考了.咖啡的钱看作总的背包容量,1.5.10.25分别代表四种物品的重量, ...

  3. poj 1787 Charlie's Change

    // 题意 给定一个数p,要求用四种币值为1,5,10,25的硬币拼成p,并且硬币数要最多,如果无解输出"Charlie cannot buy coffee.",1<=p&l ...

  4. POJ 1787 Charlie&#39;s Change

    多重背包 可行性+路径记录 题意是说你要用很多其它的零钱去买咖啡.最后输出你分别要用的 1,5 ,10 .25 的钱的数量. 多重背包二进制分解.然后记录下 这个状态.最后逆向推就可以. #inclu ...

  5. poj 1787 背包+记录路径

    http://poj.org/problem?id=1787 Charlie's Change Time Limit: 1000MS   Memory Limit: 30000K Total Subm ...

  6. (多重背包+记录路径)Charlie's Change (poj 1787)

    http://poj.org/problem?id=1787   描述 Charlie is a driver of Advanced Cargo Movement, Ltd. Charlie dri ...

  7. Charlie's Change POJ - 1787

    Time limit 1000 ms Memory limit 30000 kB description Charlie is a driver of Advanced Cargo Movement, ...

  8. 专题复习--背包问题+例题(HDU 2602 、POJ 2063、 POJ 1787、 UVA 674 、UVA 147)

    *注 虽然没什么人看我的博客但我还是要认认真真写给自己看 背包问题应用场景给定 n 种物品和一个背包.物品 i 的重量是 w i ,其价值为 v i ,背包的容量为C.应该如何选择装入背包中的物品,使 ...

  9. Charlie's Change(完全背包+路径记忆)

    Charlie's Change Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 3176   Accepted: 913 D ...

随机推荐

  1. Java语言编码规范(Java Code Conventions)

    Java语言编码规范(Java Code Conventions) 名称 Java语言编码规范(Java Code Conventions) 译者 晨光(Morning) 简介 本文档讲述了Java语 ...

  2. 【mysql】MySQL存储IP地址

    为什么要问如何存储IP 首先就来阐明一下部分人得反问:为什么要问IP得怎样存,直接varchar类型不就得了吗? 其实做任何程序设计都要在功能实现的基础上最大限度的优化性能.而数据库设计是程序设计中不 ...

  3. 【mysql】mysql分表和表分区详解

    为什么要分表和分区? 日常开发中我们经常会遇到大表的情况,所谓的大表是指存储了百万级乃至千万级条记录的表.这样的表过于庞大,导致数据库在查询和插入的时候耗时太长,性能低下,如果涉及联合查询的情况,性能 ...

  4. jquery.find()

    http://www.365mini.com/page/jquery-find.htm

  5. openstack(liberty):部署实验平台(二,简单版本软件安装 part2)

    继续前面的part1,将后续的compute以及network部分的安装过程记录完毕! 首先说说compute部分nova的安装. n1.准备工作.创建数据库,配置权限!(密码依旧是openstack ...

  6. 修改webftp,在线文件管理

    项目中要添加一个文件管理功能,允许用户维护自己的静态HTML文件. 在网上找了一个现成的在线PHP文件管理工具:webftp 下载地址:http://down.chinaz.com/soft/3067 ...

  7. JDBC的URL设置allowMultiQueries的原因

    如下的一个普通JDBC示例: String user ="root";String password = "root";String url = "j ...

  8. MySQL使用Union创建视图报错

    mysql> select * from test_main; +----+-------+ | id | value | +----+-------+ |  1 | ONE   | |  2  ...

  9. Maven错误在这里看【项目无法成功编译由于maven未成功下载依赖导致】

  10. 推荐一个css帮助手册的版本 同时提供chm和在线

    版本保持更新 目录分类妥当 查阅很方便 就是习惯了jquery那种风格,略有不适应. 包括最新css3的内容 网址: http://css.doyoe.com/ chm下载地址: http://css ...