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

Вниз

Еще о сортировке :)   Найти похожие ветки 

 
kronprince ©   (2003-01-03 12:09) [0]

Нужен быстрый метод сортировки последовательности типа:
2, 2аб, 30, 00, 10, 20, 1а, 1б, 1, а1, 0, б2....
в последовательность:
0, 00, 1, 1а, а1, 1б, 2, 2аб, б2, 10, 20, 30...
причем 1а=1а только приоритет выше чем а1.


 
Igorek ©   (2003-01-03 13:18) [1]

Кормэн и др. "Алгоритмы: построение и анализ"


 
vuk ©   (2003-01-03 14:10) [2]

>Нужен быстрый метод сортировки
Воистину, чтобы задать вопрос нужно знать половину ответа. :o)
У Вас же ответ прямо в вопросе! Метод так и называется - быстрая сортировка (она же QuickSort). Смотрите реализацию TList.Sort, TStringList.QuickSort. Там легко задаются правила сравнения и выполняется произвольная сортировка.


 
Igorek ©   (2003-01-03 15:21) [3]


> vuk © (03.01.03 14:10)

"Быстрая сортировка" на самом деле не самая быстрая ;-)
Ответ зависит от того, какое время работы требуется.


 
vuk ©   (2003-01-03 18:08) [4]

Не самая быстрая, это да, но она обладает достаточной скоростью и легко реализуется для линейных структур данных с произвольным доступом. Хотя, в принципе и для списочных структур реализуема(типа двусвязных списков), но там она имеет более низкую производительность именно из-за невозможности произвольного доступа.



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

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

Наверх




Память: 0.47 MB
Время: 0.023 c
1-62581
gururu
2003-01-08 03:15
2003.01.20
Глюк в проге


1-62628
jon1
2003-01-08 17:00
2003.01.20
Работа с компонентом DBGrid


4-62900
Monster_Kot
2002-12-02 07:37
2003.01.20
Послать сообшение (как командой Net Send)?


8-62671
Fredericco
2002-07-24 16:58
2003.01.20
Микрофон.


3-62420
бобёр
2002-12-26 16:03
2003.01.20
IB