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

Вниз

Быстрый StringList   Найти похожие ветки 

 
Lfx   (2002-03-29 13:18) [0]

Добрый день, Мастера!

Не подскажет ли кто-нибудь, где достать аналог TStringList, в котором был бы быстрый IndexOf? Ну чтобы он индексировал деревом или т.п.?

Спасибо.


 
Digitman ©   (2002-03-29 13:33) [1]

Не найдешь ты такого. И не ищи. Создать индекс по строкам нефиксированной длины в принципе нереально.

А вот отсортировать в порядке возрастания строки в TStringList перед IndexOf() не помешало бы. В ряде случаев это дает некоторый выигрыш во времени поиска.


 
MBo ©   (2002-03-29 13:47) [2]

Если TStringList сортирован, IndexOf ищет двоичным поиском, а не простым перебором. Быстрее может быть только хэширование, но при этом (в простых реализациях) теряется возможность динамического изменения размера списка.
Как вариант (если нельзя сортировать данные) можно попробовать завести второй, сортированный список, в Objects которого хранить номер строки в исходном списке. Конечно, накладные расходы значительны, но если поиск выполняется намного чаще, чем добавление, на это можно пойти.


 
Lfx   (2002-03-29 13:49) [3]

Уважаемый Digitman!

Спасибо за совет. Сортировка действительно ему помогла.



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

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

Наверх




Память: 0.47 MB
Время: 0.036 c
1-32903
PlaZZma
2002-03-29 16:52
2002.04.11
Как избавиться от мигания Image?


1-32796
Елена
2002-04-01 06:48
2002.04.11
вопрос по TreeView


1-32848
IronHawk
2002-03-27 10:32
2002.04.11
Приветствую Мастеров ! Прошу бААААльшой помощи, неоткажите....


7-32988
davile
2002-01-11 19:04
2002.04.11
Как сделать , чтобы рабочий стол не запускался


1-32799
Crime134
2002-03-31 22:21
2002.04.11
Строки