Pagini recente » Cod sursa (job #1518930) | Cod sursa (job #664261) | Cod sursa (job #1280246) | Cod sursa (job #1539674) | Cod sursa (job #2038104)
#include<bits/stdc++.h>
using namespace std;
int i, j, e[10005], c[10005], dp[10005][10005], E, n;
int main()
{
ifstream f("energii.in");
ofstream g("energii.out");
f >> n >> E;
for(i = 1;i <= n;i++)
f >> e[i] >> c[i];
for(j = c[1];j <= E;j++)
dp[1][j] = e[1];
for(i = 2;i <= n;i++)
for(j = 1;j <= 3 * E;j++)
{
dp[i][j] = dp[i - 1][j];
if(c[i] <= j)dp[i][j] = max(dp[i][j], dp[i - 1][j - c[i]] + e[i]);
if(dp[i][j] >= E)
{
g << j;
return 0;
}
}
g << "-1";
return 0;
}