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

•  DeLiKaTeS Tetris (Тетрис)  4 648

•  TDictionary Custom Sort  6 651

•  Fast Watermark Sources  6 432

•  3D Designer  9 370

•  Sik Screen Capture  6 758

•  Patch Maker  7 152

•  Айболит (remote control)  7 162

•  ListBox Drag & Drop  6 014

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

•  Графические эффекты  7 343

•  Рисование по маске  6 631

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

•  Canvas Drawing  5 883

•  Рисование Луны  5 606

•  Поворот изображения  5 110

•  Рисование стержней  3 683

•  Paint on Shape  2 913

•  Генератор кроссвордов  3 810

•  Головоломка Paletto  3 062

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

•  Пазл Numbrix  2 547

•  Заборы и коммивояжеры  3 265

•  Игра HIP  2 237

•  Игра Go (Го)  2 171

•  Симулятор лифта  2 549

•  Программа укладки плитки  2 186

•  Генератор лабиринта  2 686

•  Проверка числового ввода  2 331

•  HEX View  2 667

•  Физический маятник  2 302

 
скрыть

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



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

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

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

КОММЕНТАРИЙ

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

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


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

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