Pagini recente » Cod sursa (job #1313610) | Cod sursa (job #2678376) | Cod sursa (job #3241209) | Cod sursa (job #2766953) | Cod sursa (job #1574610)
#define INF 0x3f3f3f3f
#include<fstream>
#define nMax 1001
#define eMax 5001
using namespace std;
int N, W, C[nMax], E[nMax], dp[nMax][eMax], m;
ifstream f("energii.in");
ofstream g("energii.out");
int main()
{
f >> N >> W;
for(int i = 1; i <= N; i++)
f >> E[i] >> C[i];
for (int i = 0; i <= N; i++)
for (int j = 0; j <= W; j++)
dp[i][j] = INF;
for (int i = 1; i <= N; i++){
for(int j = 1; j <= W; j++){
if(E[i] <= j)
dp[i][j] = min(dp[i - 1][j], dp[i - 1][j - E[i]] + C[i]);
else dp[i][j] = min(dp[i - 1][j], C[i]);
}
}
for (int i = 1; i <= N; i++){
for (int j = 1; j <= W; j++)
g << dp[i][j] << " ";
g << endl;
}
if(dp[N][W] == INF) g << -1;
else g << dp[N][W];
return 0;
}