题解 | #兑换零钱#
兑换零钱
https://www.nowcoder.com/practice/67b93e5d5b85442eb950b89c8b77bc72
#include <bits/stdc++.h>
using namespace std;
const int N = 1e4 + 10;
int v[N], w[N], f[N], n, V;
int main()
{
cin >> n >> V;
for (int i = 0; i < n; i++) {
cin >> v[i];
}
memset(f, 0x3f, sizeof(f));
f[0] = 0;
for (int i = 0; i < n; i++) {
for (int j = v[i]; j <= V; j++) {
f[j] = min(f[j], f[j - v[i]] + 1);
}
}
if (f[V] > V) f[V] = -1;
cout << f[V] << endl;
return 0;
}

叮咚买菜工作强度 221人发布