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

Вниз

Как фильтровать дерево ? По шаблону.   Найти похожие ветки 

 
Кен ©   (2004-02-05 01:42) [0]

Список - понятно. Просто удаляю все строки не соответствующие шаблону и всё, а с деревом как быть ? Ведь тут надо все ветки обходить, пустые удалять, не пустые оставлять. Да ещё с рекурсиями ... Всё как-то сложно очень. Нет ли простого способа ? Может уже готовые функции для этого есть ?


 
Savage   (2004-02-05 03:20) [1]

Подробней задачку обрисуй


 
Кен ©   (2004-02-05 03:56) [2]

Надо оставить в дереве только те строки в которых содержится определённый текст. Остальные удалить. Как их грамотно удалить ?


 
TUser ©   (2004-02-05 11:42) [3]


> Надо оставить в дереве только те строки

Дерево состоит не из строк, а из нодов. Если нод Х надо удалить, то что надо делать с его чайлдами. Все ведь от задачи твоей зависит - чайлды можно тоже удалить, можно их переместить в другой нод, по каким-то тебе известным критериям выбираемый. Если надо удалить пустые ветки, то рекурсией. Типа

function IsFree(Node):boolean;
var f:boolean;
begin
f:=false;
foreach (знаю, что в паскале форича нет, но что имеется в виду - понятно) Chiled do
f:=f or IsFree(Child);
if not f then result:=true else begin
// Удалить нод
result:=false; end;
end;



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

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

Наверх




Память: 0.47 MB
Время: 0.029 c
14-39096
Danilka
2004-01-22 14:30
2004.02.13
Light Alloy потерялся.


14-39015
TGrigory
2004-01-22 22:18
2004.02.13
Компонет для отображения лога чата


1-38813
Aleksandr
2004-02-03 11:15
2004.02.13
Как сделать в ListBox перетаскиваемые мышкой Itemы?


14-39078
ИМХО
2004-01-23 22:45
2004.02.13
Теория Большого Взрыва


3-38693
onix
2004-01-21 14:48
2004.02.13
Исполнение процедуры в FB