Pagini recente » Cod sursa (job #1389288) | Cod sursa (job #38315) | Cod sursa (job #3218929) | Cod sursa (job #1869541) | Cod sursa (job #889666)
Cod sursa(job #889666)
program saddasdasdasd;
type mat=array[1..1000,1..1000]of integer;
var d:mat;
n:integer;
f,g:text;
procedure initializare;
var i,j:integer;
begin
for i:=1 to n do
begin
for j:=1 to n do read(f,d[i,j]);
readln(f);
end;
end;
procedure drumuri(var d:mat);
var i,j,k:integer;
begin
for k:=1 to n do
for i:=1 to n do
for j:=1 to n do
if (d[i,k]<>0)and(d[k,j]<>0)and (i<>j) then
if (d[i,j]>d[i,k]+d[k,j])or(d[i,j]=0) then d[i,j]:=d[i,k]+d[k,j];
//a[i][k] && a[k][j] &&
//(a[i][j] > a[i][k] + a[k][j] || !a[i][j]) && i != j)
end;
procedure afisare_drum;
var i,j:integer;
begin
for i:=1 to n do
begin
for j:=1 to n do write(g,d[i,j],' ');
writeln(g);
end;
end;
begin
assign(f,'royfloyd.in');reset(f);
assign(g,'royfloyd.out');rewrite(g);
readln(f,n);
initializare;
drumuri(d);
afisare_drum;
close(f);close(g);
end.