Pagini recente » Cod sursa (job #1390986) | Cod sursa (job #2579291) | Cod sursa (job #1920541) | Cod sursa (job #933696) | Cod sursa (job #1164149)
#include <fstream>
using namespace std;
ifstream f("energii.in");
ofstream g("energii.out");
struct art { int w,c; } V[1009];
int n,W,sum,sol,dp[20009];
int main()
{
f >> n >> W;
for(int i=1; i<=n; i++)
{
f >> V[i].w >> V[i].c;
sum += V[i].w;
}
if(sum < W) g << "-1\n";
else
{
dp[0] = 1;
sol = 2000000000;
for(int i=1; i<=n; i++)
{
for(int j=W; j>=0; j--)
{
if(dp[j])
{
if(dp[j+V[i].w])
{
if(dp[j+V[i].w] > dp[j] + V[i].c)
dp[j+V[i].w] = dp[j] + V[i].c;
}
else dp[j+V[i].w] = dp[j] + V[i].c;
if(j+V[i].w >= W && dp[j+V[i].w] < sol) sol = dp[j+V[i].w];
}
}
}
g << sol-1 << '\n';
}
g.close();
return 0;
}