Pagini recente » Cod sursa (job #2217512) | Cod sursa (job #1750400) | Cod sursa (job #1239068) | Cod sursa (job #1385919) | Cod sursa (job #854051)
Cod sursa(job #854051)
var a:array[1..2,1..1000000] of longint;
b:array[1..100000] of longint;
i,m,n,s:longint;
f,g:text;
ok:boolean;
begin
assign (f,'bfs.in');assign (g,'bfs.out');
reset(f);rewrite (g);
read (f,n,m,s);
for i:=1 to m do
read (f,a[1,i], a[2,i]);
b[s]:=1;
ok:=true;
while ok do begin
ok:=false;
for i:=1 to m do
if (b[a[1,i]]<>0) and ( (b[a[2,i]]=0) or (b[a[2,i]]>b[a[1,i]]+1)) then
begin b[a[2,i]]:=b[a[1,i]]+1;
ok:=true;end;
end;
for i:=1 to n do
write (g,b[i]-1,' ');
close(g);
end.