Hi,
ich habe versucht in Bluej Bubblesort zu programmieren.
Eine Liste mit Zufälligen zahlen erstellne funktioniert auch, aber ich krieg es nicht hin, dass mein sortierbefehl funktioniert.
Bluej meckert beim ausführen immer : java.lang.Array.IndeyOutOfBoundsException:7
Kann mal jemand rübergucken und mir sagen was ich ändern muss? ich häng da jetzt schon 2 Stunden dran -.-
Hier ist der Code:
Deine Schleife betritt den Rumpf in der letzten Iteration mit b = Bubble.length, was einen Zugriff auf Bubble bereits ungütlig machen würde. Du greifst aber dazu noch auf Bubble[b+1] zu und überschreitest den Array-Index somit sogar um 2. Vielleicht war Bubble.length - 1 beim Schleifenkopf gemeint oder so?
Hi,
es war -1 im Schleifenkopf gemeint.
Wo habe ich b= Bubble.length geschrieben??? Ich hab doch nur b=0 geschrieben.
Aber schonmal danke für die schnelle Antwort ^^
Das kommt drauf an, womit die letzte Iteration noch durchlaufen werden soll. Normalerweise möchte man sie bis length - 1 laufen lassen, dann schreibt man als Bedingung: i < length
Aber da du im Rumpf auf [i + 1] zugreifst, möchtest du vermutlich diese Bedingung nutzen: i < length - 1, denn dann wird die letzte Iteration mit i = length - 2 betreten und der Zugriff [i + 1] bezieht sich auf length - 1, also auf das letzte Element
Sry wegen den vielen fragen, aber ich hab mir das mieste selbst beigebracht, weil das in der Schule zu langsam vorangeht und kann das deswegen noch nicht so gut.
So sollte die ArrayIndexOutOfBoundsException zumindest weg sein, ja. Ob das Programm dadurch das tut, was du erwartest, steht auf einem anderen Blatt Finde es durch Probieren heraus und falls du Fälle findest, die nicht richtig sortiert werden, bau überall System.out.println-Zeilen ein, damit du weißt, was da vor sich geht und so.. falls du damit den Fehler nicht findest (sofern einer vorhanden ist, hab's mir wirklich nicht angeschaut), melde dich einfach nochmal
Hi,
ich bins nochma.
Ich krieg es einfach nicht hin, das das Programm die Array mit dem Bubblesortprinzip sortiert.
Habe ich irgendwo einen Logikfehler???
Hier ist nochmal der Code
Ja. Du gehst das Array genau einmal von vorne nach hinten durch und vertauscht dabei benachbarte Elemente, falls sie in der falschen Reihenfolge stehen. Aber was, wenn nicht-benachbarte Elemente vertauscht werden müssen, z.B. das vorderste mit dem hintersten?
Tipp: BubbleSort benötigt zwei verschachtelte Schleifen, damit jedes Element die Chance hat, mit jedem anderen vertauscht zu werden, falls das nötig ist.
So, ich habs jetzt endlich geschaft, dankeschön für die Hilfe.
Meine Fehler waren im nachhinein recht dumm XD
Hie einmal der nun funktionierende Code, falls den jemand haben möchte.