Bubblesort Programm funktioniert nicht

Newnoob

Mitglied
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:
Java:
public class Bubblesort
{
   
    private int x;
    private int y;
    int[] Bubble = new int[7];

    public Bubblesort()
    {
        
        x = 0;
        y=0;
        
        for( int i= 0; i<Bubble.length; i++){
             Bubble[i] = (int)(Math.random() * 50 + 1);
        }
        
    }
    public void Ausgabe() {
        System.out.print("\n"); 
         for( int i= 0; i<Bubble.length; i++){
             System.out.println (Bubble[i]);
        }

}
public void sort(){
    
    for( int b= 0; b<Bubble.length+1; b++){
            y=Bubble[b+1];
             
             x=Bubble[b];
           
           
             Bubble[b+1]=x;
            
            Bubble[b]=y;
             
        }
     
        
}

 public static  void ClearScreen(){ 
  for (int rows=0;rows<=25;rows++) 
System.out.print("\n"); 
}
}
LG
Newnoob
 

rme

Top Contributor
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?
 

Newnoob

Mitglied
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 ^^
 

rme

Top Contributor
Direkt geschrieben hast du das nicht, aber:
Java:
    for( int b= 0; b<Bubble.length+1; b++){

Dadurch wird die letzte Iteration mit b = Bubble.length betreten :)
 

rme

Top Contributor
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 :)
 

Newnoob

Mitglied
Sollte das dann so funktionieren?
Java:
for( int b= 0; b<Bubble.length-1; b++){
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.
 

rme

Top Contributor
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 :)
 

Newnoob

Mitglied
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
Java:
public class Bubblesort
{
   
    private int x;
    private int y;
    int[] Bubble = new int[7];
    private int z;

    public Bubblesort()
    {
        
        x = 0;
        y=0;
        z=1;
        
        for( int i= 0; i<Bubble.length; i++){
             Bubble[i] = (int)(Math.random() * 50 + 1);
        }
        
    }
    public void Ausgabe() {
        System.out.print("\n"); 
         for( int i= 0; i<Bubble.length; i++){
             System.out.println (Bubble[i]);
        }
        

}
public void sort(){
   
    for (int i=0; i<Bubble.length-1;i++){
        if (Bubble[i]>Bubble[i+1]){
            x=Bubble[i];
            y=Bubble[i+1];
            Bubble[i]=y;
            Bubble[i+1]=x;
            
     
        
    }
}
}
public static  void ClearScreen(){ 
  for (int rows=0;rows<=25;rows++) 
System.out.print("\n"); 
}
}
Und die Ausgabe einer unsortierten Liste, die kam als ich es probiert habe:
14
37
10
14
40
7
19

Und dem (unerwünschten) Ergebnis:
14
10
14
37
7
19
40
 

rme

Top Contributor
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.
 

Newnoob

Mitglied
Hab ich das im meinem Programm nicht so, das das 1. mit dem 2. dann das 3. mit dem 3. dann das 3. mit dem 4. ... element vertauscht/verglichen wird??
 

Newnoob

Mitglied
Ohhh, XD
Ich glaub ich hab verstanden was du meintest, du meintest das so oder?´
Java:
public void sort(){
   
   for (int b=0; b==7;b++){
    for (int i=0; i<Bubble.length-1;i++){
        if (Bubble[i]>Bubble[i+1]){
            x=Bubble[i];
            y=Bubble[i+1];
            Bubble[i]=y;
            Bubble[i+1]=x;
            
     
        
    }
}
}
}
 

rme

Top Contributor
Ich will dir nicht zu viel verraten, du möchtest ja was lernen und dazu sind Fehler perfekt geeignet ;)

Funktioniert's denn jetzt besser?
 

Newnoob

Mitglied
Nein, hat nicht funktioniert ^^
Hab jetzt mal nochmal den Wikipedia Artikel angegucckt und bin dabei meinen Fehler zu berichtigen (hoffe ich)
 

Newnoob

Mitglied
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.
Java:
public class Bubblesort
{
   
    private int x;
    private int y;
    int[] Bubble = new int[7];
    private int z;

    public Bubblesort()
    {
        
        x = 0;
        y=0;
        z=1;
        
        for( int i= 0; i<Bubble.length; i++){
             Bubble[i] = (int)(Math.random() * 50 + 1);
        }
        
    }
    public void Ausgabe() {
        System.out.print("\n"); 
         for( int i= 0; i<Bubble.length; i++){
             System.out.println (Bubble[i]);
        }
        

}
public void sort(){
   
  for(int i=Bubble.length;i>1; i=i-1){
      for(int n=0; n<i-1;n++){
          if (Bubble[n]> Bubble[n+1]){
              x=Bubble[n];
              y=Bubble[n+1];
              Bubble[n]=y;
              Bubble[n+1]=x;
            }
        }
    }
}
public static  void ClearScreen(){ 
  for (int rows=0;rows<=25;rows++) 
System.out.print("\n"); 
}
}
LG
Newnoob
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Generischer Bubblesort Java Basics - Anfänger-Themen 19
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
H Bubblesort-Algorithms Java Basics - Anfänger-Themen 14
I Bubblesort Java Basics - Anfänger-Themen 1
L Bubblesort in Batch Script Java Basics - Anfänger-Themen 15
D Bubblesort Java Basics - Anfänger-Themen 2
G Bubblesort Array der Größe 10 Java Basics - Anfänger-Themen 1
M Bubblesort ohne Array Java Basics - Anfänger-Themen 30
V_Fynn03 Erste Schritte BubbleSort Quelltext funktioniert noch nicht Java Basics - Anfänger-Themen 1
H Bubblesort-Zwei Integer auf Dekade vergleichen. Java Basics - Anfänger-Themen 6
R Erste Schritte Einsteiger-Video Bubblesort Bewertung Java Basics - Anfänger-Themen 11
D Array/Bubblesort Fehlermeldungen Java Basics - Anfänger-Themen 1
U BubbleSort Problem Java Basics - Anfänger-Themen 2
L Array und Bubblesort Java Basics - Anfänger-Themen 4
L Frage zu BubbleSort Algorithmus Java Basics - Anfänger-Themen 2
T BubbleSort Java Basics - Anfänger-Themen 9
O Bubblesort allgemeiner schreiben Java Basics - Anfänger-Themen 5
J Interface Bubblesort soll Arrays beliebiger Referenztypen sortieren können. Java Basics - Anfänger-Themen 5
N Mein Bubblesort sortiert mein Array nicht Java Basics - Anfänger-Themen 2
E BubbleSort Java Basics - Anfänger-Themen 2
J Erste Schritte Bubblesort Java Basics - Anfänger-Themen 6
G Array mit BubbleSort sortieren Java Basics - Anfänger-Themen 2
R BubbleSort Java Basics - Anfänger-Themen 4
R BubbleSort Java Basics - Anfänger-Themen 15
A BubbleSort Java Basics - Anfänger-Themen 7
B BubbleSort Java Basics - Anfänger-Themen 10
R BubbleSort Java Basics - Anfänger-Themen 6
C Klassen BubbleSort was passiert mit dem Index ? Java Basics - Anfänger-Themen 2
B Sortiermethode bei Bubblesort Java Basics - Anfänger-Themen 15
G Bubblesort - Falsche Sortierung Java Basics - Anfänger-Themen 6
M Laufzeitanalyse Bubblesort Java Basics - Anfänger-Themen 7
T BubbleSort Java Basics - Anfänger-Themen 2
P BubbleSort-Methode Java Basics - Anfänger-Themen 18
M BubbleSort (Sortieralgorithmus) Java Basics - Anfänger-Themen 28
B Bubblesort Java Basics - Anfänger-Themen 70
G Bubblesort ohne Schleifen Java Basics - Anfänger-Themen 10
F Bubblesort, Insertsort Java Basics - Anfänger-Themen 2
K BubbleSort Hausaufgabe Java Basics - Anfänger-Themen 20
B Bubblesort-Algorithmus und Testklasse Java Basics - Anfänger-Themen 5
c_sidi90 Array mit Bubblesort sortieren Java Basics - Anfänger-Themen 8
B Java Bubblesort Java Basics - Anfänger-Themen 5
F Bubblesort---Frage von Anfänger Java Basics - Anfänger-Themen 2
E BubbleSort kleiner Fehler? Java Basics - Anfänger-Themen 14
B BubbleSort Java Basics - Anfänger-Themen 5
L Bubblesort: Exception in Thread "main" Java Basics - Anfänger-Themen 5
K Einfaches Bubblesort Java Basics - Anfänger-Themen 11
W Problem mit BubbleSort und Array Java Basics - Anfänger-Themen 10
Spin taschenrechner incl bubblesort Java Basics - Anfänger-Themen 5
G Bubblesort Java Basics - Anfänger-Themen 2
Binary.Coder Bubblesort in einfachen unmissverständlichen Sätzen Java Basics - Anfänger-Themen 2
B Bubblesort Verfahren Java Basics - Anfänger-Themen 2
C Bubblesort Java Basics - Anfänger-Themen 5
I BubbleSort-Algorithmus Java Basics - Anfänger-Themen 8
G Bubblesort Java Basics - Anfänger-Themen 23
G Bubblesort Java Basics - Anfänger-Themen 15
kulturfenster BubbleSort Java Basics - Anfänger-Themen 7
T Bekomme Fehler mit Bubblesort Java Basics - Anfänger-Themen 2
T Zahlen mit Bubblesort sortieren Java Basics - Anfänger-Themen 2
D Bubblesort und Array Java Basics - Anfänger-Themen 6
T Bubblesort Java Basics - Anfänger-Themen 5
L Bubblesort funzt nicht Java Basics - Anfänger-Themen 3
N bubblesort Java Basics - Anfänger-Themen 4
T BubbleSort optimieren ??? Java Basics - Anfänger-Themen 26
tomzen Programm ignoriert in der Ausführung Code Java Basics - Anfänger-Themen 8
S Erstes Programm: Hallo Welt funktioniert nicht. Java Basics - Anfänger-Themen 3
A "Hello World"-Programm läuft nicht Java Basics - Anfänger-Themen 16
J Delay erzeugen, ohne Programm zu blockieren Java Basics - Anfänger-Themen 7
Ü Dead Code im Programm? Java Basics - Anfänger-Themen 13
M Java Mail Programm Java Basics - Anfänger-Themen 4
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
M Mini Jar-Programm Java Basics - Anfänger-Themen 51
G JTable Listselectionlistener friert das Programm ein Java Basics - Anfänger-Themen 8
M Das Programm stellt nichts dar Java Basics - Anfänger-Themen 2
K Programm compilierbar aber nicht ausführbar... Java Basics - Anfänger-Themen 21
Z Programm Ideen Java Basics - Anfänger-Themen 8
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
T Programm stürzt ab Java Basics - Anfänger-Themen 40
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
G Programm läuft durch, ohne Eingabe aus dem Chat abzuwarten Java Basics - Anfänger-Themen 4
N Programm Funktioniert mit .txt Datei aber nicht mit .rtf Datei Java Basics - Anfänger-Themen 2
N Interpreter-Fehler Compiler zeigt keine Fehler an, aber das Programm läuft nicht (BlueJ) Java Basics - Anfänger-Themen 2
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
Jul1n4tor Programm mit Scanner und If-Statements Java Basics - Anfänger-Themen 2
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
K Ist das Programm schlecht bzw. schlampig programmiert ? Java Basics - Anfänger-Themen 9
Zrebna Kann Java Programm nicht in Konsole ausführen Java Basics - Anfänger-Themen 1
K Warum läuft das Programm nicht(bzw. nicht richtig) Java Basics - Anfänger-Themen 4
M Von Eclipse zum richtigen Programm Java Basics - Anfänger-Themen 1
nbergmann IntelliJ: Wie lade ich ein fertiges Programm aus dem Lehrbuch? Java Basics - Anfänger-Themen 26
D Anfängerfrage zu meinem Programm. Java Basics - Anfänger-Themen 15
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 22
I Jetty starten von Programm (Main) Java Basics - Anfänger-Themen 27
Kydo Programm Beschreibung Java Basics - Anfänger-Themen 3
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 7
T Java FXML selbes Fenster verschiedene Stellen im Programm Java Basics - Anfänger-Themen 5
frager2345 Programm erstellen ohne Autoboxing und Unboxing Java Basics - Anfänger-Themen 13

Ähnliche Java Themen

Neue Themen


Oben