poj3260 The Fewest Coins
来源:互联网 发布:spring mvc js国际化 编辑:程序博客网 时间:2024/05/16 14:42
Description
Farmer John has gone to town to buy some farm supplies. Being a very efficient man, he always pays for his goods in such a way that the smallest number of coins changes hands, i.e., the number of coins he uses to pay plus the number of coins he receives in change is minimized. Help him to determine what this minimum number is.
FJ wants to buy T (1 ≤ T ≤ 10,000) cents of supplies. The currency system has N (1 ≤ N ≤ 100) different coins, with values V1, V2, ..., VN (1 ≤ Vi ≤ 120). Farmer John is carrying C1 coins of value V1, C2 coins of value V2, ...., andCN coins of value VN (0 ≤ Ci ≤ 10,000). The shopkeeper has an unlimited supply of all the coins, and always makes change in the most efficient manner (although Farmer John must be sure to pay in a way that makes it possible to make the correct change).
Input
Line 2: N space-separated integers, respectively V1, V2, ..., VN coins (V1, ...VN)
Line 3: N space-separated integers, respectively C1, C2, ..., CN
Output
Sample Input
3 705 25 505 2 1
Sample Output
3
Hint
Farmer John pays 75 cents using a 50 cents and a 25 cents coin, and receives a 5 cents coin in change, for a total of 3 coins used in the transaction.
这题思路是一次枚举钱数,从要买物品的价格到最大值(即上界),这里最大值为24400(查百度的,用鸽笼原理),然后用num1[m]表示买m元买家最少要用的硬币数(可以用多重背包),num2[m]表示找钱m元最少要用的硬币数(可以用完全背包,因为数量无限),然后设一个值ans,用min(ans,num1[i]+num2[i-jiage])求出最小的硬币数。
#include<stdio.h>#include<string.h>#define inf 88888888int min(int a,int b){return a<b?a:b;}int num1[25500],num2[25500],v[105],num[105],w[105];int main(){int n,i,j,jiage,ans,k,sum;int m=24450;while(scanf("%d%d",&n,&jiage)!=EOF){for(i=1;i<=n;i++){scanf("%d",&w[i]);v[i]=1;}for(i=1;i<=n;i++){scanf("%d",&num[i]);}for(j=1;j<=m;j++){num1[j]=num2[j]=inf;}num1[0]=num2[0]=0;for(i=1;i<=n;i++){for(j=w[i];j<=m;j++){if(num2[j-w[i]]!=inf){num2[j]=min(num2[j],num2[j-w[i]]+v[i]);}}ans=num[i]*w[i];if(ans>=m){for(j=w[i];j<=m;j++){if(num1[j-w[i]]!=inf){num1[j]=min(num1[j],num1[j-w[i]]+v[i]);}}}else{k=1;sum=0;while(sum+k<num[i]){sum+=k;for(j=m;j>=k*w[i];j--){if(num1[j-k*w[i]]!=inf){num1[j]=min(num1[j],num1[j-k*w[i]]+k*v[i]);}}k=k*2;}k=num[i]-sum;for(j=m;j>=k*w[i];j--){if(num1[j-k*w[i]]!=inf){num1[j]=min(num1[j],num1[j-k*w[i]]+k*v[i]);}}}}ans=inf;for(i=jiage;i<=m;i++){if(num1[i]==inf || num2[i-jiage]==inf)continue;if(ans>num1[i]+num2[i-jiage]){ans=num1[i]+num2[i-jiage];}}if(ans!=inf)printf("%d\n",ans);else printf("-1\n");}return 0;}
- poj3260 The Fewest Coins
- poj3260 The Fewest Coins
- 【POJ3260】【The Fewest Coins】
- 【POJ3260】【The Fewest Coins】
- POJ3260 The Fewest Coins
- POJ3260:The Fewest Coins(混合背包)
- POJ3260---The Fewest Coins(混合背包)
- POJ3260--The Fewest Coins(混合背包)
- POJ3260 The Fewest Coins 多重背包+完全背包
- 【POJ3260】The Fewest Coins 多重背包+完全背包
- poj3260[USACO2006,Dec]The Fewest Coins最少找零
- POJ The Fewest Coins
- The Fewest Coins POJ
- poj 3260 the fewest coins
- POJ-3260-The Fewest Coins
- POJ 3260 The Fewest Coins
- poj 3260 The Fewest Coins
- poj 3260 The Fewest Coins
- 苹果发布ipa包的几种方式讲解
- 剑指offer: 不用加减乘除做加法
- android开发环境搭建 eclipse ADT
- 正则表达式一
- iOS开发拓展篇—音频处理(音乐播放器2)
- poj3260 The Fewest Coins
- CocoaPods使用
- 黑马程序员 网络编程
- IBM RTC在软件开发过程的应用
- cstring 转 cstringarray 转 BYTE
- 高仿微信本地图片选择器
- 消除“Permission is only granted to system apps”错误
- iOS开发拓展篇—音频处理(音乐播放器3)
- CocoaPods进阶