Hilfe bei der Fehlersuche

tridentifer

Mitglied
Hi Community,
ich bin relativ neu beim Programmieren und versuche gerade meine erste "schweere Aufgabe" zu verwirklichen:
Ein Programm, dass eine beliebige Anzahl an double's aus der Konsole einließt und von klein nach groß sorteirt ausgiebt. Leider kommt immer eine Fehlermeldung. Das einlesen funktioniert noch, aber dannach kommt der Error.
Hier ist der Code:
Code:
import java.util.Scanner;
public class Reset {
   
    static int position;
   
    public static void main(String[] args) {
        Scanner Eingabe = new Scanner(System.in);
        System.out.print("Wie viele Zahlen wollen sie sortieren?");
        int anzahl = Eingabe.nextInt();
        System.out.println("Geben sie bitte ihre Zahlen ein:");
        int use = 0;
        double[] unsortiert= new double[anzahl];
        while(use<anzahl){                                            //Eingabe der Zahlen
            unsortiert[use] = Eingabe.nextDouble();
            use++;
        }
        use = 0;
        int[] positionen = new int[anzahl];
        double[] fertig = new double[anzahl];
        while(use<anzahl){
            positionen[use]=Stelle(unsortiert[use], fertig, anzahl);
            fertig[positionen[use]]= unsortiert[use];
            use++;
        }
        use = 0;
        int use2 =1;
        while(use<anzahl){
            System.out.println("Die " + use2 + ". Zahl ist " + fertig[use]);
        }
       
       
       
       
       
        Eingabe.close();
    }
   
   
    public static int Stelle(double x, double[] Feld, int Länge ){        //Herausfinden, an welche Stelle die Zahl gehört
        int use = 0;   
        while(Länge>use){
            if(x<Feld[use])
                return use;
            use++;
        }
        return Länge;
    }
   
    public static double[] Einsortieren(int x, double[] Feld, int Stelle, int Länge){    // Beginn der Einsortierungsmethode
        int use = 0;
        int use2 = Länge;
        while(Länge>use){
            if(x<Feld[use]){
                while(x<Feld[use2]){
                    Feld[use2 + 1]=Feld[use2];
                    use2--;
               
                }
                Feld[use]=x;
                return Feld;
            }
            use++;
        }
        return Feld;
       
    }
   
}



Liebe Grüße und Danke im Vorraus.

Ps: Mein Programmierstil ist leider nicht allzu übersichtlich.
 

JStein52

Top Contributor
In Stelle(...) return'st du immer Länge, und das ist der dritte Parameter, also = anzahl, also verkehrt.

Edit: also nicht immer Länge, aber manchmal !
 

Sugan

Mitglied
Hi tridentifer,

also dein Fehler liegt irgendwo bei den While-Schleifen, soweit alles klar. Ich schau mir das mal näher an...

Was genau soll denn passieren?

LG
Sugan
 

Sugan

Mitglied
Also eine sache hab ich noch gefunden, is aber auch noch nicht die ganze Lösung:

hier
Java:
 positionen[use] = Stelle(unsortiert[use], fertig, anzahl);
übergibst du mit "fertig" ein leeres Array. stattdessen wäre es besser "unsortiert" zu übergeben.

funktioniert aber auch noch nicht...
 

JStein52

Top Contributor
Er schreibt in jedem Schleifendurchlauf was rein. Beim ersten Mal ist es leer (d.h. enthält lauter 0) beim zweiten Mal schon nicht mehr ganz so leer usw.
 

JStein52

Top Contributor
Und ob sein Sortieralgo funktioniert habe ich noch nicht so genau durchdacht, sollte er aber relativ einfach erkennen können.
 

tridentifer

Mitglied
Ich hab jetzt noch use ++; und use2++; nach dem letzten prin-befehl ergänzt.
Folgendes passiert:
Als Position wird wahrscheinlich immer 0 aus der Methode ausgegeben, da müsste also der Fehler liegen.
Denn hier ist die Console:

Wie viele Zahlen wollen sie sortieren?"4"
Geben sie bitte ihre Zahlen ein:
"1"
"2"
"5"
"4"
Die 1. Zahl ist 4.0
Die 2. Zahl ist 0.0
Die 3. Zahl ist 0.0
Die 4. Zahl ist 0.0

Ich habe zur Verdeutlichung meine Eingaben in " " gesetzt.
 

JStein52

Top Contributor
Ok, du suchst nun also einen Sortieralgorithmus für ein double[] - Array. Schau dir den mal an:

Code:
    private static double[] shakersort(double[] inArray) {
        double k;
        int l = inArray.length;
        for (int i=0; i < l;) {
            for (int j = i; j < l - 1; j++) {
                if (inArray[j] > inArray[j + 1]) {
                    k = inArray[j];
                    inArray[j] = inArray[j + 1];
                    inArray[j + 1] = k;
                }
            }
            l--;
            for (int j = l - 1; j >= i; j--) {
                if (inArray[j] > inArray[j + 1]) {
                    k = inArray[j];
                    inArray[j] = inArray[j + 1];
                    inArray[j + 1] = k;
                }
            }
            i++;
        }
    return inArray;
    }
 

Sugan

Mitglied
also mich haben deine While-schleifen irgendwie irritiert, und hab daher mit for gearbeitet.
wenn ich bei anzahl = 3 "fertig" übergebe, dann beinhaltet das array "positionen" nach dem aufruf folgende 3 Zahlen: 3, 3, 3
wenn man stattdessen "unsortiert" übergibt, dann beinhaltet das array "positionen" nach dem aufruf folgende 3 Zahlen: 2, 0, 3

Das war meine Eingabe:
Wie viele Zahlen wollen sie sortieren?"3"
Geben sie bitte ihre Zahlen ein:
"4"
"2"
"5"

FAZIT:
1.) du musst auf jeden fall das Array "unsortiert" übergeben und nicht "fertig"
2.) dein Sortier-Algorhythmus is nicht richtig...
warum nimmst du stattdessen nicht einfach Arrays.sort?

Das ganze programm wäre viel kürzer:

Java:
import java.util.Arrays;
import java.util.Scanner;
public class Reset {
  
    static int position;
  
    public static void main(String[] args) {
        Scanner Eingabe = new Scanner(System.in);
        System.out.print("Wie viele Zahlen wollen sie sortieren?");
        int anzahl = Eingabe.nextInt();
        System.out.println("Geben sie bitte ihre Zahlen ein:");
        int use = 0;
        double[] unsortiert= new double[anzahl];
        while(use<anzahl){                                            //Eingabe der Zahlen
            unsortiert[use] = Eingabe.nextDouble();
            use++;
        }
        System.out.println("unsortiert: "+ unsortiert[0]+" "+ unsortiert[1]+" "+ unsortiert[2]+" ");
        Arrays.sort(unsortiert);
        System.out.println("sortiert: "+ unsortiert[0]+" "+ unsortiert[1]+" "+ unsortiert[2]+" ");

        Eingabe.close();
    }
  
   /*
    public static int Stelle(double x, double[] Feld, int Länge ){        //Herausfinden, an welche Stelle die Zahl gehört
        int use = 0; 
        while(Länge>use){
            if(x<Feld[use])
                return use;
            use++;
        }
        return Länge;
      
    }
  
    public static double[] Einsortieren(int x, double[] Feld, int Stelle, int Länge){    // Beginn der Einsortierungsmethode
        int use = 0;
        int use2 = Länge;
        while(Länge>use){
            if(x<Feld[use]){
                while(x<Feld[use2]){
                    Feld[use2 + 1]=Feld[use2];
                    use2--;
              
                }
                Feld[use]=x;
                return Feld;
            }
            use++;
        }
        return Feld;
      
    }
   */
}


LG
Sugan
 

JStein52

Top Contributor
Also ich gehe mal davon aus du wolltest zur Übung das Sortieren selber implementieren ? Sonst wäre es natürlich wirklich mit Arrays.sort() viel einfacher. Aber eben unsportlich ;);)
 

tridentifer

Mitglied
Erstmal ein dickes Dankeschön
an euch alle. Jetzt funktioniert alles.
JStein52 hat recht, ich bin noch relativ am Anfang meiner Programmierzeit, es diente nur als Übung.

Durch eure alle Posts und Codes kam dann die "Erleuchtung":
Es geht viel einfacher, wenn ich die beiden Zahlen nebeneinander vergleiche und gegebenenfalls vertausche wenn die Reihenfolge nicht stimmt. Jetzt habe ich haufenweise Code gespart.

Nochmals Danke.

Ps: Für die interessierten, hier ist der Code
Code:
import java.util.Scanner;
public class Sortieren {
     
    public static void main(String[] args) {
        Scanner Eingabe = new Scanner(System.in);
        System.out.print("Wie viele Zahlen wollen sie sortieren?");
        int anzahl = Eingabe.nextInt();
        System.out.println("Geben sie bitte ihre Zahlen ein:");
        int use = 0;
        double[] Zahlen= new double[anzahl];
        while(use<anzahl){                                               //Eingabe der Zahlen
            Zahlen[use] = Eingabe.nextDouble();                        //
            use++;                                                        //
        }                                                                //           
      
       for(int i = 0;i<anzahl;){                                        //Zahlensortiermaschiene
               for(int z =1; z<anzahl;z++){
                   if(Zahlen[z-1]>Zahlen[z]){
                       double k = Zahlen[z];
                       Zahlen[z]=Zahlen[z-1];
                       Zahlen[z-1]=k;
                   }
                  
               }
          
           i++;
       }
       use= 0;
       while(use<anzahl){
           use++;
           System.out.println("Die " + use + ". Zahl ist " + Zahlen[use-1]);
       }
      
      
      
        Eingabe.close();
    }
  
  
}
 

Flown

Administrator
Mitarbeiter
Dein Algorithmus sieht nach einem BubbleSort aus, der aber nicht ganz richtig ist. Vielleicht solltest du auch Sachen clustern und in eigene Methoden auslagern. Desweitern schließt man den System.in nicht manuell (auch nicht indirekt über Scanner).
Nach ein wenig Aufräumarbeit sieht das dann so aus:
Java:
import java.util.Scanner;

public class Test {
  public static void main(String... args) {
    Scanner eingabe = new Scanner(System.in);
    System.out.print("Wie viele Zahlen wollen sie sortieren?");
    int anzahl = eingabe.nextInt();
    System.out.println("Geben sie bitte ihre Zahlen ein:");
    double[] zahlen = new double[anzahl];
    for (int i = 0; i < anzahl; i++) {
      zahlen[i] = eingabe.nextDouble();
    }
    bubbleSort(zahlen);
    for (int i = 0; i < anzahl; i++) {
      System.out.format("Die %d. Zahl ist %.2f%n", i + 1, zahlen[i]);
    }
  }
 
  public static void bubbleSort(double[] arr) {
    for (int i = 0; i < arr.length; i++) {
      boolean swapped = false;
      for (int j = arr.length - 1; j > i; j--) {
        if (arr[j] < arr[j - 1]) {
          double t = arr[j];
          arr[j] = arr[j - 1];
          arr[j - 1] = t;
          swapped = true;
        }
      }
      if (!swapped) {
        break;
      }
    }
  }
}
PS: Gute Erklärung zu den Sortieralgorithmen mit Pseudocodes: http://www.sorting-algorithms.com/
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S brauche hilfe bei Fehlersuche Java Basics - Anfänger-Themen 7
N Hilfe bei Fehlersuche Java Basics - Anfänger-Themen 2
? hilfe bei Fehlersuche Sortierung List Java Basics - Anfänger-Themen 5
G Hilfe bei fehlersuche Java Basics - Anfänger-Themen 3
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
E Hilfe bei rekursiver Funktion Java Basics - Anfänger-Themen 3
H pdf stempel - Hilfe erbeten Java Basics - Anfänger-Themen 6
KogoroMori21 Wann ist der richtige Zeitpunkt, um sich Hilfe zu suchen? (Bin Informatik-Student) Java Basics - Anfänger-Themen 10
A Hilfe beim Lesen von Pfaden und Systemvariablen Java Basics - Anfänger-Themen 3
F RegEx Hilfe Java Basics - Anfänger-Themen 5
S Hilfe bei Endlosschleife Java Basics - Anfänger-Themen 2
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
U Ich bräuchte Hilfe Java Basics - Anfänger-Themen 1
Say abstract class und Objekt erzeugen - Dringend Hilfe Java Basics - Anfänger-Themen 10
Justin4687 Benötige Hilfe bei folgender Aufgabe Java Basics - Anfänger-Themen 2
aero043 Hilfe bei BlueJ Hausübung Java Basics - Anfänger-Themen 27
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
P Hilfe gesucht Java Basics - Anfänger-Themen 11
D Hilfe bei Calculator Test Java Basics - Anfänger-Themen 15
R Hilfe bei Aufgabe Java Basics - Anfänger-Themen 4
Zentriks Hilfe zu Sieb des Eratosthenes ohne boolean Java Basics - Anfänger-Themen 5
R Java Bücher hilfe Java Basics - Anfänger-Themen 9
U HILFE! - per ActionListener Felder enablen....... Java Basics - Anfänger-Themen 5
I Scheduling: "Quartz" verwenden, Hilfe bei Umstellung Java Basics - Anfänger-Themen 3
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
L Hilfe! Liste mit Items werden ausgegeben aber nicht in zufälliger Reihenfolge Java Basics - Anfänger-Themen 6
Ekooekoo Hilfe spiel Java Basics - Anfänger-Themen 5
SpiritsHuner Hilfe!! Java Basics - Anfänger-Themen 16
Lacotto Java Kurs Aufgaben Hilfe Java Basics - Anfänger-Themen 14
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
M HILFE JPanel - Graphics Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
X Hilfe beim Übertragen in eine For-Schleife Java Basics - Anfänger-Themen 1
Neuling47 Denkfehler? Hilfe Java Basics - Anfänger-Themen 11
S Hilfe bei Umänderung von Java Code Java Basics - Anfänger-Themen 16
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
X Erste Schritte Hilfe bei einem kleinen Spiel. Java Basics - Anfänger-Themen 19
D Bitte um Hilfe muss es schnellstmöglich erledigen Java Basics - Anfänger-Themen 15
L Hilfe bei RegEx Java Basics - Anfänger-Themen 4
I Bitte um Hilfe zu unterstehenden Code Java Basics - Anfänger-Themen 6
B Brauche Hilfe zu einem Code Java Basics - Anfänger-Themen 5
Neuling47 bräuchte dringend hilfe Java Basics - Anfänger-Themen 6
D Bräuchte Hilfe im Bezug zum printarray() Java Basics - Anfänger-Themen 4
M Bitte um Hilfe bei 2DArrays Java Basics - Anfänger-Themen 8
HeiTim Array hilfe Java Basics - Anfänger-Themen 14
M LCD-Ziffern-Hilfe Java Basics - Anfänger-Themen 6
özkan hilfe!! Java Basics - Anfänger-Themen 4
C Hilfe bei einem Anfängerprojekt Java Basics - Anfänger-Themen 25
D Abrechnung bitte um hilfe Java Basics - Anfänger-Themen 25
J Brauche Hilfe bei for-each Aufgabe Java Basics - Anfänger-Themen 1
D Zahlentabelle Anfänger braucht Hilfe Java Basics - Anfänger-Themen 1
HeiTim Brauche Hilfe soll ein nummeriertes Feld ausgeben lassen Java Basics - Anfänger-Themen 17
S Interaktive Abfrage, Hilfe mit Schleifen! Java Basics - Anfänger-Themen 6
N Hilfe bei der Installation Java Basics - Anfänger-Themen 2
J Brauche Hilfe bei Aufgabe Java Basics - Anfänger-Themen 4
S Hilfe bei Programmierung einer Hotelabrechnung Java Basics - Anfänger-Themen 5
enjoykimii Strukturierte Programmierung Hilfe Java Basics - Anfänger-Themen 29
H Bräuchte hilfe Java Basics - Anfänger-Themen 3
D Snake-Spiel ähnliche Aufgabe Hilfe Java Basics - Anfänger-Themen 3
H Brauche Hilfe Java Basics - Anfänger-Themen 2
D Dijkstra Algorithmus Hilfe!! Java Basics - Anfänger-Themen 9
H Hilfe Java Basics - Anfänger-Themen 6
H Brauche hilfe Java Basics - Anfänger-Themen 3
M Hilfe - Array Aufgabe Java Basics - Anfänger-Themen 8
R Schulaufgabe, Bruache Hilfe mit non-static Methoden Java Basics - Anfänger-Themen 2
kevkev Hilfe bei Schiffe versenken Java Basics - Anfänger-Themen 5
FelixxF Erste Schritte Hilfe bei Fußball Manager Java Basics - Anfänger-Themen 2
C Brauche Hilfe beim Schreiben eines Programmes :/ Java Basics - Anfänger-Themen 1
C Brauche Hilfe um ein Programm zu schreiben Java Basics - Anfänger-Themen 8
josfe1234 Hilfe access denied ("java.io.FilePermission" " " "read") Java Basics - Anfänger-Themen 12
Vivien Hilfe bei Type Conversion Java Basics - Anfänger-Themen 3
Leo0909 Ich brauche Hilfe bei dieser Aufgabe Java Basics - Anfänger-Themen 2
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
J Doppelt verkette Liste ich bitte um Hilfe Java Basics - Anfänger-Themen 4
N Laufzeitberechnung - dringende Hilfe! Java Basics - Anfänger-Themen 1
G Java Hilfe Java Basics - Anfänger-Themen 3
J Java List, Bitte um Hilfe Java Basics - Anfänger-Themen 15
J Java List, bitte um Hilfe Java Basics - Anfänger-Themen 3
U anfänger braucht hilfe . wir konnten die aufgaben nicht beantworten Java Basics - Anfänger-Themen 5
A Schleifen, Hilfe! Java Basics - Anfänger-Themen 6
LeonDerStudent Hilfe bei Uniprojekt Java Basics - Anfänger-Themen 2
H Brauche Hilfe in Java Eclipse Programmieraufgabe Neuling Java Basics - Anfänger-Themen 3
B Hilfe bei Map Liste erstellen Java Basics - Anfänger-Themen 10
Kapfski Was habe ich falsch gemacht? Hilfe! Java Basics - Anfänger-Themen 17
R Java (Eclipse) "Lagerverwaltung" HILFE Java Basics - Anfänger-Themen 13
M Bräuchte Hilfe bei diesen Methoden Java Basics - Anfänger-Themen 4
dieter000 Aufgabe Hilfe Java Basics - Anfänger-Themen 18
Gaudimagspam Dringend Java Hilfe benötigt Java Basics - Anfänger-Themen 19
jonathanpizza Hilfe bei einer Übungsaufgabe Java Basics - Anfänger-Themen 6
dieter000 Hilfe bei dem Beispiel, wie gehe ich sowas am besten an? Java Basics - Anfänger-Themen 32
jonathanpizza Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
Q Hilfe auf Aufgabe(Matrixmultiplikation) Java Basics - Anfänger-Themen 1
jonathanpizza Hilfe bei der Aufgabe Java Basics - Anfänger-Themen 19
pry bitte Hilfe beim Kreditrechner objektorientiert Java Basics - Anfänger-Themen 6
R Hilfe bei removeduplicates Java Basics - Anfänger-Themen 5
D Brauche Dringend Hilfe...Prozedur/Funktionsprozedur Ergebnis augeben Java Basics - Anfänger-Themen 11
marcooooo einmal noch schnell hilfe bitte:/ Java Basics - Anfänger-Themen 2
Q Hilfe bei Hausaufgeben Java Basics - Anfänger-Themen 2
J Hilfe beim Label animieren Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben