1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63: 64: 65: 66: 67: 68: 69: 70: 71: 72: 73: 74: 75: 76: 77:
| unit Unit1;
interface
uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls;
type TForm1 = class(TForm) Button1: TButton; Memo1: TMemo; procedure MergeSort(links, rechts:integer); procedure Button1Click(Sender: TObject); private b: array[0..9] of integer; public end;
var Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.MergeSort(links, rechts:integer); var i,j,k,mid:integer;
begin if (rechts-links>0) then begin mid := (rechts+links) div 2 ; MergeSort(links, mid); MergeSort(mid+1, rechts); for i:=mid downto links do b[i] := StrToInt(Memo1.Lines[i]); for j:=mid+1 to rechts do b[rechts+mid+1-j] := StrToInt(Memo1.Lines[j]); i := links; j := rechts; for k:=links to rechts do begin if b[i]<b[j] then begin Memo1.Lines[k]:=IntToStr(b[i]); i:=i+1; end else begin Memo1.Lines[k]:=IntToStr(b[j]); j:=j-1; end; end; end end; procedure TForm1.Button1Click(Sender: TObject); var i : integer; begin memo1.lines.Clear; memo1.lines.Add('Original'); For i := 0 to 9 do memo1.lines.Add(inttostr(random(10000))); memo1.lines.Add('Sortiert'); For i := 0 to 9 do memo1.lines.Add(memo1.lines[i+1]); i := memo1.lines.count-1; mergesort(i-9,i); end;
end. |