这道题有个小小的坎,就是低于5块不能选,大于5块,可以任意选,所以就在初始条件判断一下剩余钱数,然后如果大于5的话,这时候就要用到贪心的思想,只要大于等于5,先找最大的那个,然后剩下的再去用背包去选择,这样的结果一定是最优的。因为最大的那个一定会被选中,剩下多少钱都无所谓,用背包可以获得剩下的最优解,所以最后也是最优解
代码如下
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = ;
int dp[N];
int value[N];
int main()
{
int n;
while (scanf("%d", &n) == , n)
{
for (int i = ; i < n; i++)
scanf("%d", &value[i]);
int v;
scanf("%d", &v);
if (v < )//如果初始条件都不满足,直接输出金额
{
printf("%d\n", v);
continue;
}
sort(value, value + n);//排序
memset(dp, , sizeof(dp));
//01背包
for (int i = ; i < n - ; i++)
{
for (int j = v - ; j >= value[i]; j--)
if (dp[j] < dp[j - value[i]] + value[i])
dp[j] = dp[j - value[i]] + value[i];
}
printf("%d\n", v - dp[v - ] - value[n - ]);
}
return ;
}