Cod sursa(job #394149)

Utilizator skullLepadat Mihai-Alexandru skull Data 10 februarie 2010 17:02:09
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator fpc Status done
Runda Arhiva educationala Marime 0.63 kb
var a:array [1..100,1..100] of integer;
    n,i,j,k:integer;
    f,g:text;
begin
assign(f,'royfloyd.in');reset(f);
readln(f,n);
for i:=1 to n do
    begin
    for j:=1 to n do
        read(f,a[i,j]);
    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]<>0) and (a[k,j]<>0) and (i<>j) then
               if (a[i,j]>a[i,k]+a[k,j]) or (a[i,j]=0) then
                  a[i,j]:=a[i,k]+a[k,j];
assign(g,'royfloyd.out');rewrite(g);
for i:=1 to n do
    begin
    for j:=1 to n do
        write(g,a[i,j],' ');
    writeln(g);
    end;
close(g);
end.