Pagini recente » Cod sursa (job #1121293) | Cod sursa (job #894168) | Cod sursa (job #1011240) | Cod sursa (job #220929) | Cod sursa (job #2443663)
#include <fstream>
#define maxn 1001
#define maxe 5001
#define inf 1<<29
using namespace std;
ifstream f("energii.in");
ofstream g("energii.out");
int main(){
int n, energy, i, j;
f>>n>>energy;
int dp[maxe], cost[maxn], power[maxn];
for(i=0;i<=energy;i++)
dp[i]=inf;
for(i=1;i<=n;i++){
f>>power[i]>>cost[i];
}
for(i=1;i<=n;i++){
for(j=energy;j>=power[i];j--){
dp[j]=min(dp[j],dp[j-power[i]]+cost[i]);
}
for(j=1;j<=power[i];j++)
dp[j]=min(dp[j],cost[i]);
}
if(dp[energy]!=inf){
g<<dp[energy]<<"\n";
}
else
g<<"-1"<<"\n";
}