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

Вниз

Быстрый алгоритм сжатия упаковки(не архивация) массива   Найти похожие ветки 

 
@!!ex ©   (2007-12-07 20:29) [0]

Есть массив записей.
Нужно упаковать массив.
В записи есть поле Handle.
Это значит упорядочить его так, чтобы все элементы с Handle=0 лежали в конце массива.
НИчего умнее сортировки придумать не могу...


 
Efir   (2007-12-07 20:31) [1]

Т. е. нужно отсортировать?


 
@!!ex ©   (2007-12-07 20:40) [2]

> [1] Efir   (07.12.07 20:31)

хм. в принципе да.
Но полюбому это можно реализовать как то быстрее чем обычная сортировка. Ведь элементы делятся только на два типа 0 и не 0.


 
Efir   (2007-12-07 20:52) [3]

Ну тогда наверно можно одним проходом отсортировать.


 
Anatoly Podgoretsky ©   (2007-12-07 20:58) [4]

Это не совсем сортировка в привычном смысле этого слова.
Решается за один проход, путем перемещения в конец, только не циклом for, а while.


 
Efir   (2007-12-07 21:06) [5]

Чё нить типа:
xo - указатель на начало
хк - указатель на конец массива
 1) если справа 0, то dec(xk) иначе смотрим слева
 2) если слева 0 - меняем местами и inc(xo), dec(xk)
 3) если слева не 0 то inc(xo), пока слева не будет 0.



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

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

Наверх




Память: 0.47 MB
Время: 0.01 c
8-1170839529
ZMRaven
2007-02-07 12:12
2008.01.06
dspack


2-1197279243
ZLinX
2007-12-10 12:34
2008.01.06
Удаление Обьектов


2-1197204719
azl
2007-12-09 15:51
2008.01.06
ORDER BY (Query1.Edit) Cannot modify a read-only dataset


15-1196676079
Cerber
2007-12-03 13:01
2008.01.06
adsl и соеденение через сотовый телефон


1-1192260730
031178
2007-10-13 11:32
2008.01.06
TReeView