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

Вниз

Как отсортировать массив?   Найти похожие ветки 

 
kjj   (2002-04-08 10:09) [0]

Как отсортировать по алфавиту массив (array[1..100] of string) с заданными значениями его элементов? Впринципе можно скинуть его в бд и отсортировать её, но эта операция в программе часто повторяется и затормозит программу. Может можно сделать как-то побыстрее(скорость работы проги) работая с самим массивом?


 
Alx2 ©   (2002-04-08 11:03) [1]


procedure SortStringArray(Var SortList: Array of String);
procedure QuickSort(L, R: Integer);
var
I, J: Integer;
P, T: String;
begin
repeat
I := L;
J := R;
P := SortList[(L + R) shr 1];
repeat
while SortList[I]<P do
Inc(I);
while SortList[J]>P do
Dec(J);
if I <= J then
begin
T := SortList[I];
SortList[I] := SortList[J];
SortList[J] := T;
Inc(I);
Dec(J);
end;
until I > J;
if L < J then
QuickSort(L, J);
L := I;
until I >= R;
end;

begin
QuickSort(Low(SortList),High(SortList));
end;


Пример использования:

Var MyArr : array [1..10] of String; // Размеры MyArr могуть быть любыми :)
begin
// Заполняем чем-то MyArr
SortStringArray(MyArr); // Сортируем по возрастанию
// Пользуемся отсортированным.
end;


 
MBo ©   (2002-04-08 13:34) [2]

а TStringList не устроит?


 
Андрей Сенченко ©   (2002-04-08 14:38) [3]

Вот сюда загляни :
http://alglib.chat.ru/


 
Dok_3D ©   (2002-04-08 15:25) [4]

Методом пузырька


 
Alx2 ©   (2002-04-08 15:31) [5]

>Методом пузырька
Вопрос был в том: можно сделать как-то побыстрее(скорость работы проги)
Хотя, если еще пузырька два взять, то скорость уже по барабану будет.


 
AFROLOV   (2002-04-08 15:33) [6]

Пузырек - полный отстой по скорости. Если чистый Pascal то QuickSort а если не хочется программировать то TStringList.


 
Андрей Сенченко ©   (2002-04-08 15:37) [7]

>> AFROLOV (08.04.02 15:33)
>> Пузырек - полный отстой по скорости.

Зато всего две строки кода :)


 
Anatoly Podgoretsky ©   (2002-04-08 15:46) [8]

При таких объемах и говорить про скорость.


 
Alx2 ©   (2002-04-08 15:51) [9]

>Anatoly Podgoretsky
"эта операция в программе часто повторяется"



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

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

Наверх




Память: 0.48 MB
Время: 0.009 c
1-57707
Delph
2002-04-08 12:29
2002.04.18
Ошибка при динамическом вызове DLL


1-57679
BWG
2002-04-07 14:22
2002.04.18
Как передать в процдуру динамический массив и там его изменить?


1-57801
Aleksandr
2002-04-05 16:05
2002.04.18
Почему сепараторы в ToolBar e стали с вертикальной чертой?


14-57854
Dimedrol
2002-03-11 11:43
2002.04.18
2 винта - 2 системы. Как ?


1-57777
Erik
2002-04-05 22:20
2002.04.18
Передача буфера.