Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > Delphi программирование > Общие вопросы Delphi
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 11.02.2009, 22:32   #1
Serious
Пользователь
 
Регистрация: 09.02.2009
Сообщений: 29
По умолчанию Быстрая сортировка

мне нужно отсортировать масив s[i]
ранее заданы переменные s как массив и i передаю в эту процедуру.
На данный момент у меня такая сортировка стоит. Но она очень меленная.
Плиз на основе моих данных сделайте быструю сортировку

Код:
procedure TForm1.sort(I:longint);
var
z:longint;
begin
q:=i;
for z:=1 to q do
for i:=1 to q do
if s[i]> s[i+1] then
begin
c:=s[i];
s[i]:=s[i+1];
s[i+1]:=c;
end;
end;
И ещё такой вопрос у меня есть массив в котором содержится много разных данных. Отсортированных по имени.
и там данные типа game.part1.rar.rar game.part3.rar.rar game.part11.rar.rar game.part17.rar.rar, plesen.avi, win7.part1.iso.rar win7.part4.iso.rar win7.iso.part6.rar win7.part10.iso.rar
как мне зделать что бы из этих нескольких данных собирались строки в которых было начало допустим win7.part(1,4,6,10).iso.rar уже в простую строчку
Пример для этого выходной строчки game.part(1,3,11,17).rar.rar, plesen. avi, win7.part(1,4,6,10).iso.rar

Последний раз редактировалось Serious; 11.02.2009 в 22:38.
Serious вне форума Ответить с цитированием
Старый 11.02.2009, 23:13   #2
maladoy
delphi-ст!
Форумчанин
 
Аватар для maladoy
 
Регистрация: 02.01.2009
Сообщений: 825
По умолчанию

Цитата:
Алгоритим быстрой сортировки массива

Автор: Dimka Maslov
WEB-сайт: http://delphibase.endimus.com

{ **** UBPFD *********** by delphibase.endimus.com ****
>> Алгоритим быстрой сортировки массива

Функция, показывающая пример реализации алгоритма быстрой сортировки
целочисленного массива. Легко может быть переработан для массивов
другого типа или объектов типа TList, TStringList и т. д.

Используемые параметры
IntArray - указатель на первый элемент массива. ВАЖНО! Индекс первого элемента
массива обязательно должен быть нулевым.

Low - минимальный индекс элемента массива
High - максимальный индекс элемента массива

Зависимости: нет
Автор: Dimka Maslov, mainbox@endimus.ru, ICQ:148442121, Санкт-Петербург
Copyright: http://www.rsdn.ru/article/?alg/bintree/sort.xml
Дата: 21 мая 2002 г.
*********************************** ****************** }
Код:
type
  PIntArray = ^TIntArray;
  TIntArray = array[0..0] of Integer;

procedure QuickSort(IntArray: PIntArray; Low, High: Integer);

  procedure Swap(Index1, Index2: Integer);
  var
    N: Integer;
  begin
    N := IntArray[Index1];
    IntArray[Index1] := IntArray[Index2];
    IntArray[Index2] := N;
  end;

var
  Mid: Integer;
  Item: Integer;
  ScanUp, ScanDown: Integer;
begin
  // Здесь реализована сортировка по убыванию
  // Для реализации по возрастанию замените операции
  // сравнения на приведённые в комментариях
  if High - Low <= 0 then
    exit;
  if High - Low = 1 then
  begin
    if IntArray[High] {<} > IntArray[Low] then
      Swap(Low, High);
    Exit;
  end;
  Mid := (High + Low) shr 1;
  Item := IntArray[Mid];
  Swap(Mid, Low);
  ScanUp := Low + 1;
  ScanDown := High;
  repeat
    while (ScanUp <= ScanDown) and (IntArray[ScanUp] {<=} >= Item) do
      Inc(ScanUp);
    while (IntArray[ScanDown] {>} < Item) do
      Dec(ScanDown);
    if (ScanUp < ScanDown) then
      Swap(ScanUp, ScanDown);
  until (ScanUp >= ScanDown);
  IntArray[Low] := IntArray[ScanDown];
  IntArray[ScanDown] := Item;
  if (Low < ScanDown - 1) then
    QuickSort(IntArray, Low, ScanDown - 1);
  if (ScanDown + 1 < High) then
    QuickSort(IntArray, ScanDown + 1, High);
end;

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

procedure TForm1.Button1Click(Sender: TObject);
var
  A: array[0..10] of Integer;
  i: Integer;
begin
  Randomize;
  for i := 0 to 10 do
    A[i] := Random(1000);
  QuickSort(@A, 0, 10);
  for i := 0 to 10 do
    Memo1.Lines.Add(IntToStr(A[i]));
end;
вступлю в команду разработчиков ПО на Delphi
maladoy вне форума Ответить с цитированием
Старый 02.11.2010, 13:38   #3
XaTa6
Новичок
Джуниор
 
Регистрация: 02.11.2010
Сообщений: 1
По умолчанию

Спасибо вам
XaTa6 вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Быстрая графика (вопрос) notnap Assembler - Ассемблер (FASM, MASM, WASM, NASM, GoASM, Gas, RosAsm, HLA) и не рекомендуем TASM 6 02.02.2009 23:49
Быстрая работа с графикой Deight Мультимедиа в Delphi 3 13.01.2009 17:49
Быстрая сортировка списка ManU Паскаль, Turbo Pascal, PascalABC.NET 2 08.12.2008 11:57
какая из трех сортировок (обменная,исчерпыванием,выбором) самая быстрая? Cyberbest Помощь студентам 2 26.04.2008 10:34
возможна ли быстрая загрузка в WebBrowser? furstenberg Работа с сетью в Delphi 10 09.01.2008 02:33