Cod sursa(job #29209)

Utilizator mihai_floreaFlorea Mihai Alexandru mihai_florea Data 8 martie 2007 19:20:46
Problema Energii Scor 5
Compilator fpc Status done
Runda Arhiva de probleme Marime 0.87 kb
program Energii;
const Inf=30000;
var a:array[1..1002,1..5002]of integer;
    eg,cg:array[1..1002]of integer;
    f:text;
    n,w:integer;
procedure Citeste;
var i:integer;
begin
assign(f,'energii.in');reset(f);
readln(f,n);
readln(f,w);
for i:=1 to n do readln(f,eg[i],cg[i]);
close(f);
end;
procedure Rezolva;
var i,j:integer;
begin
for j:=1 to w do a[1,j]:=Inf;
for j:=1 to w do if eg[1]>=j then a[1,j]:=cg[1];
for i:=2 to n do
 for j:=1 to w do
  if eg[i]>=j then
   begin
   if cg[i]<a[i-1,j] then a[i,j]:=cg[i]
                     else a[i,j]:=a[i-1,j];
   end
   else
   if a[i-1,j-eg[i]]+cg[i]<a[i-1,j] then a[i,j]:=a[i-1,j-eg[i]]+cg[i]
                                    else a[i,j]:=a[i-1,j];
assign(f,'energii.out');rewrite(f);
if a[n,w]>=w then write(f,a[n,w])
             else write(f,-1);
close(f);
end;
begin
Citeste;
Rezolva;
end.