Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 21.06.2012, 00:28
FAZA FAZA вне форума
Прохожий
 
Регистрация: 05.01.2011
Сообщения: 16
Репутация: 10
По умолчанию Сортировка слиянием: не могу разобраться как работает рекурсия!

вот сама программа, на всякий случай:
Код:
program Sortirovka_Sliyaniem;

{$APPTYPE CONSOLE}
uses  SysUtils;
Type t_type = integer;
     t_array = array [1..20] of t_type;
Procedure Merge(var A: t_array; p,q,r,g:t_type);
var n1,n2,i,j,k:integer;
    Left: t_array;
    Right: t_array;
begin
  n1:=q-p+1;
  n2:=r-q;
  for i:=1 to n1 do Left[i]:=A[p+i-1];
  for j:=1 to n2 do Right[j]:=A[q+j];
  Left[n1+1]:=high(integer);
  Right[n2+1]:=high(integer);
  i:=1;
  j:=1;
  for k:=p to r do
    if Left[i]<=Right[j] then begin
      A[k]:=Left[i];
      inc(i);
    end
    else begin
      A[k]:=Right[j];
      inc(j);
    end;
  for j:=1 to g do write(A[j]);
  write(' ! ',n1,' ',n2);
  writeln;
end;
Procedure Merge_Sort(var A: t_array; p,r,g: t_type);
var q,j: t_type;
begin
  if p<r then begin
    q:=(p+r) div 2;
    Merge_Sort(A,p,q,g);
    Merge_Sort(A,q+1,r,g);
    Merge(A,p,q,r,g); //writeln(q);
    //writeln;
    //write(q);
    //writeln;
    //for j:=1 to g do write(A[j],' ');
    writeln;
  end;

end;
var A: t_array;
    i,j,n: t_type;
begin
  //reset(input, 'input.txt');
  //rewrite(output, 'output.txt');
  read(n);
  randomize;
  for i:=1 to n do read(a[i]);//A[i]:=(random(50));
  for j:=1 to n do write(A[j],' ');
  writeln;
  writeln;
  {i:=0;

  while not seekeof do begin
    inc(i);
    read(A[i]);
  end;}
  //Merge(A,1,6,i);
  Merge_Sort(A,1,n,n);
  writeln;
  for j:=1 to n do write(A[j],' ');
  readln;
  readln;
end.
Вот часть кода, где я не понимаю:
Код:
Procedure Merge_Sort(var A: t_array; p,r,g: t_type);
var q,j: t_type;
begin
  if p<r then begin
    q:=(p+r) div 2;
    Merge_Sort(A,p,q,g);
    Merge_Sort(A,q+1,r,g);
    Merge(A,p,q,r,g); //writeln(q);
    //writeln;
    //write(q);
    //writeln;
    //for j:=1 to g do write(A[j],' ');
    writeln;
  end;

end;
Я вообще в принципе не знаю как работает рекурсивный вызов в delphi. Буду благодарен за любые ссылки, где описываются правила работы рекурсивных функций в delphi, сам я не нашёл.
Ответить с цитированием
  #2  
Старый 21.06.2012, 00:38
Аватар для angvelem
angvelem angvelem вне форума
.
 
Регистрация: 18.05.2011
Адрес: Омск
Сообщения: 3,970
Версия Delphi: 3,5,7,10,12,XE2
Репутация: выкл
По умолчанию

Цитата:
Сообщение от FAZA
... Буду благодарен за любые ссылки...
Читай, язык программирования не имеет значения.
__________________
Je venus de nulle part
55.026263 с.ш., 73.397636 в.д.
Ответить с цитированием
Этот пользователь сказал Спасибо angvelem за это полезное сообщение:
FAZA (21.06.2012)
  #3  
Старый 21.06.2012, 00:41
FAZA FAZA вне форума
Прохожий
 
Регистрация: 05.01.2011
Сообщения: 16
Репутация: 10
По умолчанию

Цитата:
Сообщение от angvelem
Читай, язык программирования не имеет значения.
самую очевидную ссылку то и не нашёл! прочитаю,разберусь и задам конкретные вопросы по алгоритму.
Ответить с цитированием
  #4  
Старый 21.06.2012, 01:55
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,047
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

На самом деле все очень просто.
Сначала входной массив делится на 2 примерно равных. После чего для каждого подмассива вызывается та же сортировка. Т.е. на выходе мы имеем 2 отсортированных массива. И теперь делается их слияние опять в один массив (просто цикл, который выбирает наименьшее/наибольшее значение среди 2х, напомню, отсортированных массивов).
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 09:10.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter