Cod sursa(job #257176)
| Utilizator | Data | 12 februarie 2009 21:17:24 | |
|---|---|---|---|
| Problema | Floyd-Warshall/Roy-Floyd | Scor | 50 |
| Compilator | fpc | Status | done |
| Runda | Arhiva educationala | Marime | 0.54 kb |
var f,g:text;
n,i,j,k:integer;
a:array[1..150,1..150] of integer;
begin
assign(f,'royfloyd.in');reset(f);
assign(g,'royfloyd.out');rewrite(g);
read(f,n);
for i:=1 to n do
for j:=1 to n do
read(f,a[i,j]);
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]) and (a[i,k]<>0) and (a[k,j]<>0) and (a[i,j]<>0) then
a[i,j]:=a[i,k]+a[k,j];
for i:=1 to n do
begin
for j:=1 to n do
write(g,a[i,j],' ');
writeln(g);
end;
close(g);
end.
