Реферат: Поиск в ширину на графах
begin {оо - размер очереди в данном цикле}
ocher[1]:=v; oo:=1; {вставка текущего индекса вершины в начало очереди}
Nw[v]:=False; {флаг на вершину текущего индекса}
while oo>0 do begin {пока есть очередь...}
p:=ocher[1];{удаление 1-го элемента из очереди и присваивание его p}
for op:=1 to oo-1 do ocher[op]:=ocher[op+1]; ocher[oo]:=0;
dec(oo);
inc(schet); {счетчик сравнений}
if not(prosm) and (ver[p]=key) then {if ver[p]=key...}
begin
find:=true;
exit; {поиск окончен}
end;
{вывод (просмотр) информации вершины}
if prosm then begin
if wherex>=79 then writeln;
write(ver[p],' ');
end;
o9:=oo;
for u:=1 to o9 do {u изменяется в диапазоне размера очереди}
begin
rebro:=false;{связи между ver[v] и ver[u] нет}
{указатель на начало списка связей v-й вершины}
m[v]:=lst[v];
while m[v]<>nil do
begin {поиск значения ver[u] в списке связей v-й вершины}
if m[v]^.inf=ver[u] then begin
{ребро есть} rebro:=true;
break;