Pagini recente » Cod sursa (job #458161) | Cod sursa (job #1033215) | Cod sursa (job #595698) | Cod sursa (job #1295422) | Cod sursa (job #1107003)
#include <cstdio>
using namespace std;
FILE *f=fopen("energii.in","r"), *g=fopen("energii.out","w");
const long long N=10000001;
long long cost[N];
struct {int e,c;} a[1001];
int main(){
int gr,w,i,j;
long long mini,s=0;
fscanf(f,"%d%d",&gr, &w);
for(i=1;i<=gr;i++){
fscanf(f,"%d%d",&a[i].e,&a[i].c);
s=s+a[i].e;
}
mini=N;
for(i=1;i<=s;i++)
cost[i]=N;
cost[0]=0;
for(i=1;i<=gr;i++)
for(j=s-a[i].e;j>=0;j--)
if(cost[j]!=N && cost[j]+a[i].c<cost[j+a[i].e]){
cost[j+a[i].e]=cost[j]+a[i].c;
if(j+a[i].e>=w && cost[j+a[i].e]<mini)
mini=cost[j+a[i].e];
}
if(mini==N)
fprintf(g,"-1");
else
fprintf(g,"%ld\n",mini);
return 0;
}