Недавно добавленные исходники

•  TDictionary Custom Sort  3 107

•  Fast Watermark Sources  2 892

•  3D Designer  4 637

•  Sik Screen Capture  3 176

•  Patch Maker  3 393

•  Айболит (remote control)  3 465

•  ListBox Drag & Drop  2 833

•  Доска для игры Реверси  78 953

•  Графические эффекты  3 730

•  Рисование по маске  3 099

•  Перетаскивание изображений  2 473

•  Canvas Drawing  2 589

•  Рисование Луны  2 428

•  Поворот изображения  2 027

•  Рисование стержней  2 062

•  Paint on Shape  1 478

•  Генератор кроссвордов  2 114

•  Головоломка Paletto  1 687

•  Теорема Монжа об окружностях  2 116

•  Пазл Numbrix  1 607

•  Заборы и коммивояжеры  1 902

•  Игра HIP  1 242

•  Игра Go (Го)  1 181

•  Симулятор лифта  1 385

•  Программа укладки плитки  1 137

•  Генератор лабиринта  1 465

•  Проверка числового ввода  1 253

•  HEX View  1 415

•  Физический маятник  1 282

•  Задача коммивояжера  1 318

 
скрыть


Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

TStringList. Неустойчивость сортировки



Автор: Илья Илларионов

Метод Sort класса TStringList является НЕУСТОЙЧИВЫМ. Это критично при работе со свойством Objects. Например, при использовании в качестве строкового индекса для добавляемых объектов. После вызова Sort объекты с одинаковым именем в списке располагаются в порядке, обратном тому, в котором были добавлены.

Способ решения - всегда сортировать список два раза. В этом случае, даже если Borland поправит недокументированный глюк с неустойчивостью сортировки, объекты все равно будут, после перекомпиляции на новых исходниках TStringList, находиться в нужном порядке.

КОММЕНТАРИЙ

Этот камень перенесен из категории БИБЛИОТЕКА.

Описываемый эффект обусловлен особенностью реализации метода сортировки QuickSort. Во первых, нельзя считать его неустойчивым, поскольку он всегда поступает однообразно по отношению к элементам с одинаковым значением ключа - а именно переупорядочивает их строго в обратном порядке по отношению к исходному. Во-вторых, как справедливо замечено в обсуждении, метод сортировки не несет ответственности за порядок сортировки при неуникальных ключах.








Copyright © 2004-2024 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте