题意:
你有10元硬币,20元硬币,50元硬币,100元硬币若干
现在有n个价格,请问最少带多少个硬币可以不用找钱能支付任意一个价格
题解:
首先10元的硬币最多只会用一个,如果用了两个,直接替换成一个10元、一个20元一定不亏。
20元的硬币最多只会用三个,如果用了四个,直接替换成一个10元、两个20元、一个50元一定不亏。
50元的硬币最多只会用一个,如果用了两个,直接替换成个50元和一个100元一定不亏。
对于任何一种情况,重复使用上述规则一定会达到一个10元硬币最多一个,20 元最多三个,50 元最多一个的情况,不会陷入重复甩锅的死循环。
然后对使用硬币的情况进行枚举,一共 2 * 4 * 2 = 16 种情况
对于每个价格,我们优先判断是否不小于100, 然后我们再把其拆出 (%100后的部分) + 100 和 若干个100进行组合,判断i个10和j个20和k个50能否组成 (%100后的部分) + 100,不能则再判断能否组成 (%100后的部分), 然后每次判断最多需要多少个100, 将16种情况枚举完取最小的答案。
AC_code:
#include<bits/stdc++.h>
#define inf 1e8
using namespace std;
bool ok[2][4][2][200];
int a[105];
void init() {
memset(ok, false, sizeof(ok));
for(int i = 0; i < 2; i ++) {
for(int