AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Mergesort quellcode

Ein Thema von Koby · begonnen am 9. Nov 2005 · letzter Beitrag vom 10. Nov 2005
Antwort Antwort
Seite 1 von 2  1 2      
Koby

Registriert seit: 7. Nov 2005
10 Beiträge
 
Delphi 5 Professional
 
#1

Mergesort quellcode

  Alt 9. Nov 2005, 16:26
Hallo Leute ,
ich wollte euch mal was fragen! Ich habe einen Code gefunden möchte ihn aber verstehen!
Könnte mir mal jemand den code Kommentieren, damit ich den code verstehe, da ich ihn verstehen
möchte! (den Code füge ich hinzu als datei)


Also würde mich freuen über jegliche Erklärungen!!!


P.S. Bin neu hier, hoffe aber was ich schon gesehen habe is das hier ne geile community
Angehängte Dateien
Dateityp: txt code-mergesort_261.txt (3,1 KB, 57x aufgerufen)
Die Dummheit des Menschen ist unendlich, bei dem Weltraum bin ich mir noch nicht sicher!!!

A.E.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.203 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: Mergesort quellcode

  Alt 9. Nov 2005, 16:53
Mergesort bei Wikipedia
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von hanselmansel
hanselmansel

Registriert seit: 23. Feb 2005
Ort: Kaiserslautern
279 Beiträge
 
Delphi 2009 Enterprise
 
#3

Re: Mergesort quellcode

  Alt 9. Nov 2005, 17:09
Um dir etwas wärmstens ans Herz zu legen: Vergiss den geposteten Code. Der mag besser aussehen, weil er so schön lang ist, aber daniels Code ist nicht nur richtiger, sondern bietet auch mehr Möglichkeit zu lernen. Und noch ein Tipp: Nimm dir irgendeinen Code vor, dazu ein Blatt Papier, und spiel ihn einfach mal durch. Daran sieht man am besten, wie er funktioniert.
Es gibt nur sehr wenige Probleme auf dieser Welt, die sich nicht mit einigen hundert Gramm Sprengstoff lösen ließen.
  Mit Zitat antworten Zitat
Koby

Registriert seit: 7. Nov 2005
10 Beiträge
 
Delphi 5 Professional
 
#4

Re: Mergesort quellcode

  Alt 9. Nov 2005, 18:07
genauer gesagt das ist mein code von meinem programm was könnte ich verbessern
Die Dummheit des Menschen ist unendlich, bei dem Weltraum bin ich mir noch nicht sicher!!!

A.E.
  Mit Zitat antworten Zitat
Der_Unwissende

Registriert seit: 13. Dez 2003
Ort: Berlin
1.756 Beiträge
 
#5

Re: Mergesort quellcode

  Alt 9. Nov 2005, 18:36
Zitat von hanselmansel:
Um dir etwas wärmstens ans Herz zu legen: Vergiss den geposteten Code. Der mag besser aussehen, weil er so schön lang ist, aber daniels Code ist nicht nur richtiger, sondern bietet auch mehr Möglichkeit zu lernen. Und noch ein Tipp: Nimm dir irgendeinen Code vor, dazu ein Blatt Papier, und spiel ihn einfach mal durch. Daran sieht man am besten, wie er funktioniert.
Wurde Koby glaube ich schonmal empfohlen. Gibt noch einen zweiten Thread in dem er nach Code für den Mergesort gesucht hat. Da die DP-Regeln aber das lösen von Hausaufgaben (im anderen Thread wurde davon ausgegangen, dass es sich um welche handelt) ablehnt, ist es wohl nicht Daniels Code gewurden.
Möchte hier auch nur noch mal darauf hinweisen, bevor jmd. Code postet.

@Koby, wie du siehst kommt auch hier der Tipp es einfach mal auf Papier durch zu spielen, dann verstehst du einfach schon ganz gut, wie Mergesort funktioniert. Wenn du dann dazu konkrete Fragen hast, stell sie.

Gruß Der Unwissende
  Mit Zitat antworten Zitat
Benutzerbild von hanselmansel
hanselmansel

Registriert seit: 23. Feb 2005
Ort: Kaiserslautern
279 Beiträge
 
Delphi 2009 Enterprise
 
#6

Re: Mergesort quellcode

  Alt 9. Nov 2005, 19:48
@ Der_Unwissende: Habe den Post falsch verstanden. Dachte, der Code wäre aus einer anderen Internet-Quelle. In diesem Fall gucken wir uns den Code doch mal genauer an.

Delphi-Quellcode:
procedure TSortierverfahren.Mergesort(var List:array of integer);
var
  laenge,x,y,z :integer;
  h_array1, h_array2 :array of integer;

begin
//Anzahl der zu sortierenden Elemente bestimmen
laenge:= length(List);
//Die Hilfsfelder auf halbe Länge dimensionieren
Setlength (h_array1, laenge div 2);
Setlength (h_array2,(laenge + 1) div 2);

//Zahlen aus der 1. Hälfte des Quellarray ins 1. Hilfsarray kopieren
for x:=0 to laenge div 2 - 1 do
  h_array1[x]:=List[x];

//Das gleiche für's 2. Hilfsarray...
for y:=0 to (laenge + 1) div 2 - 1 do
  h_array2[y]:=List[y+((laenge) div 2)];

//Wenn die Feldlänge > 2, dann rufe die Prozedur rekursiv auf.
if laenge > 2 then
  begin
  mergesort(h_array1);
  mergesort(h_array2);
  end;
z:=0;

//in die Abfrage muss ein OR...
while (length(h_array1) <> 0) and (length(h_array2) <>0) do
  begin
  //Das oberste Element vom kleineren Stapel auswählen...
  If h_array1[0] < h_array2[0] then
    Begin
    //...und ins Quellarray zurückschreiben
    List[z] := h_array1[0];

    //alle Array-Elemente um 1 nach vorne schieben
    for x:=0 to length(h_array1)-2 do
      h_array1[x]:=h_array1[x+1];

    //Array verkleinern *kreisch*
    Setlength (h_array1,length(h_array1)-1);
    end
  Else
    //the same in green...
    begin
    List[z]:=h_array2[0];

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

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

{Nach dem Durchlauf der Schleife ist eins der Hilfsfelder auf jeden Fall leer.
Wenn das andere noch Elemente enthält, dann wird es komplett ins Quell-Array
geschrieben.}


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

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

end;
Ich habe im Code mal kommentiert, was er überhaupt im Großen macht, damit du verstehst, was du gecodet hast. Hierbei habe ich (abgesehen von der While-Schleife) kein Augenmerk auf die Richtigkeit des Codes gelegt, und noch nicht mal geprüft, was davon funktioniert. (Denn funktionieren kann er praktisch noch nicht ) Wenn du den kommentierten Code gelesen hast, kannst du dich ja noch mal melden. Dann gehen wir die inhaltlichen "Ungereimtheiten" des Codes an...

MfG,

hanselmansel
Es gibt nur sehr wenige Probleme auf dieser Welt, die sich nicht mit einigen hundert Gramm Sprengstoff lösen ließen.
  Mit Zitat antworten Zitat
Koby

Registriert seit: 7. Nov 2005
10 Beiträge
 
Delphi 5 Professional
 
#7

Re: Mergesort quellcode

  Alt 10. Nov 2005, 17:28
ersteinmal voll korekt von dir hanselmann das du auf mein problem eingegangen bist!!!!

Und dann wollt ich mal sagen das das programm funktioniert so wie es da steht!



//in die Abfrage muss ein OR...
while (length(h_array1) <> 0) and (length(h_array2) <>0) do

wieso muss da ein or hin, es funktioniert auch ohne???!
Die Dummheit des Menschen ist unendlich, bei dem Weltraum bin ich mir noch nicht sicher!!!

A.E.
  Mit Zitat antworten Zitat
Benutzerbild von hanselmansel
hanselmansel

Registriert seit: 23. Feb 2005
Ort: Kaiserslautern
279 Beiträge
 
Delphi 2009 Enterprise
 
#8

Re: Mergesort quellcode

  Alt 10. Nov 2005, 17:42
Vergiss die Sache mit dem OR... hab mich im Code verlesen.
Es gibt nur sehr wenige Probleme auf dieser Welt, die sich nicht mit einigen hundert Gramm Sprengstoff lösen ließen.
  Mit Zitat antworten Zitat
Koby

Registriert seit: 7. Nov 2005
10 Beiträge
 
Delphi 5 Professional
 
#9

Re: Mergesort quellcode

  Alt 10. Nov 2005, 18:11
und waas bewirkt das kommentiert grob


procedure TSortierverfahren.Enter_bClick(Sender: TObject);
begin
Sortierverfahren.nsortiert_lb.items.add(eingabefel d_e.text);
Setlength (nsortiert,Elemente+1);
nsortiert[Elemente] := (StrToInt(eingabefeld_e.text));
Elemente:=Elemente+1;
Sortierverfahren.eingabefeld_e.text :='';
end;

procedure TSortierverfahren.Sort_bClick(Sender: TObject);
var
i:integer;
begin
Sortierverfahren.Mergesort(nsortiert);
for i:= 0 to Elemente-1 do
begin
Sortierverfahren.sortiert_lb.items.add(IntToStr(ns ortiert[i]));
end;
end;



und beim merge sort diese stelle noch die ich nicht ganz ralle unterre teil


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

if length(h_array2)<>0 then
for y:=0 to length(h_array2)-1 do
begin
List[z]:=h_array2[y];
z:=z+1;
end;
Die Dummheit des Menschen ist unendlich, bei dem Weltraum bin ich mir noch nicht sicher!!!

A.E.
  Mit Zitat antworten Zitat
Benutzerbild von hanselmansel
hanselmansel

Registriert seit: 23. Feb 2005
Ort: Kaiserslautern
279 Beiträge
 
Delphi 2009 Enterprise
 
#10

Re: Mergesort quellcode

  Alt 10. Nov 2005, 18:14
Bitte setzte um deinen Code Delphi-Tags. Dann wird er schön vom Forum formatiert und man kann ihn auch lesen, wenn man nicht a priori wusste, was drin steht.
Die oben angesprochene Schleife bricht ab, sobald eine der Listen leer ist. Das heißt aber auch, dass in der anderen Liste noch etwas drin stehen kann. Darauf wird in diesem Teil des Codes geprüft, um anschließend die Elemente zu kopieren.

MfG,

hanselmansel
Es gibt nur sehr wenige Probleme auf dieser Welt, die sich nicht mit einigen hundert Gramm Sprengstoff lösen ließen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:32 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz