[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 ...
随机推荐
- sql常用语句--转载
一.基础 .说明:创建数据库 CREATE DATABASE database-name .说明:删除数据库 drop database dbname .说明:备份sql server --- 创建 ...
- oracle的listener.ora sqlnet.ora tnsnames.ora三个文件的关联性
学习:http://www.cnblogs.com/william-lee/archive/2010/10/20/1856261.html 之前因为安装的是windows server 2008 r2 ...
- 在网页标题栏上和收藏夹显示网站logo
第一步,准备一个图标制作软件. 首先您必须了解所谓的图标(Icon)是一种特殊的图形文件格式,它是以.ico 作为扩展名.普通的图像设计软件无法使用这种格式,所以您需要到下载一个ico图标工具,本站常 ...
- .NET RSACryptoServiceProvider PEM + DER Support
http://www.christian-etter.de/?p=771 In .NET, RSACryptoServiceProvider greatly simplifies common tas ...
- 怎么优化JAVA程序的执行效率和性能?
现在java程序已经够快的了,不过有时写出了的程序效率就不怎么样,很多细节值得我们注意,比如使用StringBuffer或者StringBuilder来拼接或者操作字符串就比直接使用String效率高 ...
- Neutron分析(3)—— neutron-l3-agent
一.Layer-3 Networking Extension neutron l3作为一种API扩展,向租户提供了路由和NAT功能. l3扩展包含两种资源: router:在不同内部子网中转发数据包: ...
- 【并发编程】Executor类的继承结构
来自为知笔记(Wiz)
- 虚拟研讨会:如何设计好的RESTful API?
http://www.infoq.com/cn/articles/how-to-design-a-good-restful-api/ REST架构风格最初由Roy T. Fielding(HTTP/1 ...
- python使用xlrd模块读写Excel文件的方法
本文实例讲述了python使用xlrd模块读写Excel文件的方法.分享给大家供大家参考.具体如下: 一.安装xlrd模块 到python官网下载http://pypi.python.org/pypi ...
- system函数
system两层含义: 1.正确退出后.还需要再判断,操作成功或者操作失败. 2.错误退出. #include <stdio.h> #include <stdlib.h> #i ...