Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.06.09;
Скачать: CL | DM;

Вниз

Пмогите нарисовать двоичное дерево!!!!   Найти похожие ветки 

 
daos ©   (2003-05-25 16:56) [0]

Есть
Type Ptr=^Node;
Node=record
Info=Char;
Llink,Rlink=Ptr;
End;




Выполняетс яобратный обход
procedure PR(t:ptr); {рекурсивный обход дерева}
begin if t<>nil then
begin
PR(t^.Llink); {обойти левое поддерево}
writeln(t^.info); {попасть в корень}
PR(t^.Rlink); {обойти правое поддерево}
end;
end;


Как нарисовать дерево через Canvas????
Пытаюсь так но работает через раз

Procedure Obhod(t:TPTree;st:byte);
var
po:TPoint;
begin if t<>nil then
begin
Obhod(t^.Left,1); {обойти левое поддерево}
SL.Add(IntToStr(t^.ident)+" = "+t^.discript); {попасть в корень}
if st=1
then begin
Po.X:=FMain.Canvas.PenPos.X;
Po.y:=FMain.Canvas.PenPos.y;
FMain.Canvas.MoveTo(FMain.Canvas.PenPos.X-40,FMain.Canvas.PenPos.y+50);
FMain.Canvas.TextOut(FMain.Canvas.PenPos.X,FMain.Canvas.PenPos.y," "+IntToStr(t^.Ident)+" ");
FMain.Canvas.LineTo(FMain.Canvas.PenPos.X+10,FMain.Canvas.PenPos.y-50);
end
else if st=0 then FMain.Canvas.TextOut(FMain.Canvas.PenPos.X,FMain.Canvas.PenPos.y," "+IntToStr(t^.Ident)+" ")
else if st=2 then begin
FMain.Canvas.LineTo(FMain.Canvas.PenPos.X+10,FMain.Canvas.PenPos.y+50);
FMain.Canvas.TextOut(FMain.Canvas.PenPos.X,FMain.Canvas.PenPos.y," "+IntToStr(t^.Ident)+" ");
end;
Obhod(t^.Right,2); {обойти правое поддерево}
end;
end;


 
daos ©   (2003-05-26 14:06) [1]

Неужели никто не знает????


 
daos ©   (2003-05-27 15:18) [2]

Сделал сам.



Страницы: 1 вся ветка

Текущий архив: 2003.06.09;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.024 c
14-26767
Dim!S
2003-05-23 12:00
2003.06.09
Установка NT-систем


6-26637
SeNtiMeL
2003-04-06 00:57
2003.06.09
Как проверить порт на компьютере на свободность ?


3-26380
DBDev
2003-05-20 18:02
2003.06.09
Как записать объект OLE в поле БД минуя его запись в файл???


3-26391
Erden
2003-05-21 15:02
2003.06.09
IBQuery


14-26721
yaJohn
2003-05-22 12:17
2003.06.09
$F -> WM_PAINT