Cod sursa(job #701793)

Utilizator doruletzPetrican Teodor doruletz Data 1 martie 2012 17:52:32
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator fpc Status done
Runda Arhiva educationala Marime 0.56 kb
var f:text;
    i,j,k,n:integer;
    a:array[0..101,0..101]of integer;

begin
 assign(f,'royfloyd.in'); reset(f);
  readln(f,n);
  for i:=1 to n do begin
   for j:=1 to n do begin read(f,a[i,j]); if (a[i,j]=0)and(i<>j) then a[i,j]:=maxint; end;
   readln(f);
  end;
 close(f);

 for k:=1 to n do
  for i:=1 to n do
   for j:=1 to n do
    if a[i,k]+a[k,j]<a[i,j] then a[i,j]:=a[i,k]+a[k,j];

 assign(f,'royfloyd.out'); rewrite(f);
  for i:=1 to n do begin
   for j:=1 to n do if a[i,j]=maxint then write(f,0,' ') else write(f,a[i,j],' ');
   writeln(f);
  end;
 close(f);
end.