Cod sursa(job #503922)

Utilizator pongraczlajosLajos Pongracz pongraczlajos Data 25 noiembrie 2010 18:31:29
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator fpc Status done
Runda Arhiva educationala Marime 0.65 kb
type meret = 1..100;
     ertek = 0..1000;

var a:array[1..100,1..100] of ertek;
    i,j,k,n:meret;
    f,g:text;

Begin
assign(f,'royfloyd.in');
reset(f);
readln(f,n);

 {CITIRE}
 for i := 1 to n do
  for j := 1 to n do
  read(f,a[i,j]);

close(f);

 {ALGORITMUL FLOYD-WARSHALL/ROY-FLOYD}
  for k := 1 to n do
   for i := 1 to n do
    for j := 1 to n do
     if (a[i,k] and a[k,j] and (a[i,j]>a[i,k]+a[k,j] or not a[i,j]) and i<>j) then a[i,j] := a[i,k]+a[k,j];

assign(g,'royfloyd.out');
rewrite(g);

  {AFISARE}
  for i := 1 to n do begin
   for j := 1 to n do
    write(g,a[i,j],' ');
   writeln(g);
  end;

close(g);
End.