Einzelnen Beitrag anzeigen

Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#6

Re: Mergesort sortiert nicht...

  Alt 2. Mär 2010, 17:20
hallo DAZZLE
wo ist Dein Problem?
Wenn Du durchführst was Blub Dir geschrieben hat, dann funktioniert auch alles!

Zitat von Blup:
In der Funktion wird plötzlich mit der globalen Variable "vZaehler1" gearbeitet.
Globale Variablen sind böse, in einer Funktion die rekursiv aufgerufen wird tötlich, die haben dort nichts zu suchen.
Ersetz dort überall durch "vZahlz".
ich war so frei:
Delphi-Quellcode:
procedure Mergesort (var List:array of integer);
var
  vZahlx,
  vZahly,
  vZahlz
  vZaehlerEinlesen,
  vlaenge : integer;
  h_array1,
   h_array2 : array of integer;

begin

  vlaenge:= length(List);

//Festlegen der längen der Beiden SortierArrays
  Setlength (h_array1, vlaenge div 2);
  Setlength (h_array2,(vlaenge + 1) div 2);

//Aufteilen des ListArrays auf die Einzelarrays
for vZahlx:=0 to vlaenge div 2 - 1 do
  begin
    h_array1[vZahlx]:=List[vZahlx];
  end;

for vZahly:=0 to (vlaenge + 1) div 2 - 1 do
  begin
  h_array2[vZahly]:=List[vZahly+((vlaenge) div 2)];
  end;


// Sortieren der Array mit "mergesort"
//if vlaenge > 2 then
if vlaenge > 2 then
  begin
  mergesort(h_array1);
  mergesort(h_array2);
  end;

  vZahlz:=0;

//
while (length(h_array1) <> 0) and (length(h_array2) <>0) do
  begin
  If h_array1[0] < h_array2[0] then
    Begin
    List[vZahlz] := h_array1[0];

    for vZahlx:=0 to length(h_array1)-2 do
      h_array1[vZahlx]:=h_array1[vZahlx+1];

    Setlength (h_array1,length(h_array1)-1);
    end
  Else
    begin
    List[vZahlz]:=h_array2[0];

    for vZahly:=0 to length(h_array2)-2 do
      h_array2[vZahly]:=h_array2[vZahly+1];

    setlength(h_array2,length(h_array2)-1);
    end;
  vZahlz:=vZahlz+1;
  end;

if length(h_array1)<>0 then
  for vZahlx:=0 to length(h_array1)-1 do
    begin
    List[vZahlz]:=h_array1[vZahlx];
    vZahlz:=vZahlz+1;
    end;

if length(h_array2)<>0 then
  for vZahly:=0 to length(h_array2)-1 do
    begin
    List[vZahlz]:=h_array2[vZahly];
    vZahlz:=vZahlz+1;
    end;


end;//procedure TForm1.btu_ZufallClick(Sender: TObject);




procedure TForm1.Button1Click(Sender: TObject);
var
  i : integer;
  LIST : array [0..13] of integer;
begin
  //Einlesen der Listbox in das List-Array
  list[0]:= 2456;
  list[1]:= 56;
  list[2]:= 1456;
  list[3]:= 6;
  list[4]:= 5456;
  list[5]:= 3456;
  list[6]:= 4456;
  list[7]:= 5456;
  list[8]:= 6456;
  list[9]:= 89456;
  list[10]:= 7456;
  list[11]:= 8456;
  list[12]:=88456;
  list[13]:= 89;

  Mergesort(List);

  for i:=0 to length(list) do
    memo1.lines.add(inttostr(list[i]));
end;//procedure TForm1.btu_SortierenClick(Sender: TObject);


//******************************************************************************



end.
Gruß
K-H

Edit Tippfehler
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat