UVA 10626 Buying Coke (记忆化)

地址:点击打开链接

题意:就是买1个售价8分的饮料,然后你有的硬币有1,5,10分3种。

然后问买c瓶饮料,1次1次买,你最小的投币次数。

我们可以有几种方法:1:投8个1分  2:投1个5分的3个1分的

3:投1个10分的找3个1分的 4:投1个10分的3个1分的,找1个5分的

还有其他方案但是否是太划算。

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#include<string>
#include<iostream>
#include<queue>
#include<cmath>
#include<map>
#include<stack>
#include<bitset>
using namespace std;
#define REPF( i , a , b ) for ( int i = a ; i <= b ; ++ i )
#define REP( i , n ) for ( int i = 0 ; i < n ; ++ i )
#define CLEAR( a , x ) memset ( a , x , sizeof a )
typedef long long LL;
typedef pair<int,int>pil;
const int INF = 0x3f3f3f3f;
const int maxn=1100;
char str[maxn];
int dp[1100][155][55];
int n1,n2,n3,c;
int dfs(int num,int x1,int x2,int x3)//num,1,5,10
{
if(num==0) return 0;
int &res=dp[x1][x2][x3];
if(res!=⑴) return res;
res=INF;
if(x3>=1) res=min(res,dfs(num⑴,x1+2,×2,x3⑴)+1);
if(x2>=2) res=min(res,dfs(num⑴,x1+2,×2⑵,x3)+2);
if(x1>=8) res=min(res,dfs(num⑴,x1⑻,x2,x3)+8);
if(x1>=3&&x3>=1) res=min(res,dfs(num⑴,x1⑶,x2+1,×3⑴)+4);
if(x1>=3&&x2>=1) res=min(res,dfs(num⑴,x1⑶,x2⑴,x3)+4);
return res;
}
int main()
{
int t;
scanf("%d",&t);
while(t–)
{
scanf("%d%d%d%d",&c,&n1,&n2,&n3);
CLEAR(dp,⑴);
printf("%d
",dfs(c,n1,n2,n3));
}
return 0;
}

波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

波比源码 » UVA 10626 Buying Coke (记忆化)

发表评论

Hi, 如果你对这款模板有疑问,可以跟我联系哦!

联系站长
赞助VIP 享更多特权,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡