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

Вниз

Процедура балансировки дерева   Найти похожие ветки 

 
inoc ©   (2007-04-19 10:35) [0]

Классическая задача создания идеально сбалансированного дерева.
Берем Вирта, оттуда функция (переведенная в Delphi):

Function prootBLns(L:integer):Ttree;
Var p:Ttree; m,m1:integer;
begin
if (L=0) then P:=Nil
else begin
m:=L div 2;
m1:=l-m-1;
New(p); P^.Inf:=mas[m];
P^.A1:=ProotBLns(m);
P^.A2:=ProotBLns(m1);
end;
Result:=p;
end;

краткое пояснения: mas - массив элементов, отсортированных по возрастанию ключа.

Результат - узлы выбираются по нескольку раз (дублируются), а некоторые просто "пролетают". Может где пропустил чего?

В методе - вот такая функция, вызов prootBLns(1,n)
Function prootBLns(K,L:Word):Ttree;
Var p:Ttree; m:Word;
begin
if K>L then P:=Nil
else begin
m:=K+L div 2;
New(p); P^.Inf:=a[m];
P^.A1:=ProotBLns(K,m);
P^.A2:=ProotBLns(m+1,L);
end;
Result:=p;
end;

Результат - переполнение.


 
MBo ©   (2007-04-19 13:18) [1]

Function prootBLns(StartIdx, EndIdx):Ttree;
Var
 p:Ttree;
 m:Word;
begin
 if StartIdx > EndIdx then
   P := Nil
 else begin
    Middle := (StartIdx + EndIdx)  div 2;
    New(p);
    P^.Inf := a[Middle];
    P^.Left := ProotBLns(StartIdx, Middle - 1);
    P^.Left := ProotBLns(Middle + 1, EndIdx);
 end;
 Result:=p;
end;


 
inoc ©   (2007-04-19 14:30) [2]

Работает, спасибо!



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

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

Наверх




Память: 0.47 MB
Время: 0.038 c
2-1176975599
AK47
2007-04-19 13:39
2007.05.13
Есть 2 ADOQuery , 1 работает а вот второй нет


15-1176501642
Германн
2007-04-14 02:00
2007.05.13
Ищу ресурсы :-)


3-1172042721
Ega23
2007-02-21 10:25
2007.05.13
Проблемы с Master-Detail в LookupCombo при переводе


2-1176223059
Ezorcist
2007-04-10 20:37
2007.05.13
TMemo с событием OnDestroy?


15-1176147431
palva
2007-04-09 23:37
2007.05.13
Газета Уошингтон пост интересно прикололась