求硬币个数
有1元、5元、10元、50元、100元、500元的硬币各C1,C5,C10,C50,C100,C500枚。现在要用这些硬币来支付A元,最少需要多少枚硬币?假设本题至少存在一种支付方案。
限制条件:
0<=C1,C5,C10,C50,C100,C500<=10的9次方
0<= A <= 10的9次方
l例如:
输入:
C1 = 3 ,C2 = 2, C10 = 1 , C50 = 3, C100 = 0 ,C500 = 2 ,A = 620
输出:
6(500元硬币1枚,50元硬币2枚,10元硬币1枚,5元硬币2枚,合计6枚)
#include<bits/stdc++.h>
using namespace std;
int main(){
int V[6]={1,5,10,50,100,500};//存储硬币的面值个数
int A,t,C[100];
//输入总金额
cin>>A;
//输入各个硬币的个数
for(int i=0;i<=5;i++){
cin>>C[i];
}
int ans=0;
for(int j=5;j>=0;j--){
t=min(C[j],A/V[j]);//选择面值最大的硬币,从已知的硬币个数和最多能取到多少个该面值的硬币中挑选最小值(判断所取的硬币数是否超过所给定的)
A-=t*V[j];
ans+=t;
}
cout<<ans<<endl;
return 0;
}