Pagini recente » Cod sursa (job #2118765) | Cod sursa (job #757017) | Cod sursa (job #1882995) | Monitorul de evaluare | Cod sursa (job #3358591)
#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>
#define inf 1e9
using namespace std;
vector<int>v;
ifstream fin("energii.in");
ofstream fout("energii.out");
struct generator {
int energie, cost;
generator() :energie(0), cost(0) {};
};
const int NMAX = 10002;
vector<int>dp(NMAX, inf);
int main()
{
int n,w;
fin >> n>>w;
vector<generator>v(n);
for (int i = 0; i < n; ++i) {
fin >> v[i].energie >> v[i].cost;
}
dp[0] = 0;
int rez = inf;
for (int i = 0; i < n; ++i) {
for (int j = NMAX-1; j >=0; --j) {
if (j - v[i].energie >= 0) {
dp[j] = min(dp[j - v[i].energie] + v[i].cost, dp[j]);
if (j >= w) {
rez = min(rez, dp[j]);
}
}
}
}
if (rez == inf) {
fout << "-1";
}
else {
fout << rez;
}
return 0;
}
//=^..^=