Array.sort()

Hallo,

auf einem Übungsblatt soll durch Eingabe von Menge und Gesamtpreis ein Array nach dem Stückpreis sortiert werden. Teile des fertigen Programmes sind bereits vorgegeben. Das Array besteht aus Objekten, die initialisiert werden durch die Eingabe Menge und Gesamtpreis. Aufgabe ist es nun gewesen, eine Klasse Prices zu programmieren, welche das Interface Comparable implementiert, sodass der Vergleich anhand des Stückpreises gemacht wird.

Also man hat drei Klassen: Eine Klasse Preis, eine Klasse mit main-methode TestPreis und eine Klasse SomeUtilties.
In der Main Methode wird das Objekt Array Preis angelegt. Für die Klasse Preis wird ein Konstruktor benötigt, welcher die zwei EIngaben Menge und Gesamtpreis verarbeitet.
In der Klasse SomeUtilties ist eine Methode selectionSort zu programmieren. "Zum Sortieren werden die Methoden selectionSort und Arrays.Sort verwendet."

Es wurde bereits ein Teilstück des Programmes vorgegeben, Teile mussten also noch ersetzt werden. Mein Programm läuft, und es gibt die selbe Ausgabe wie in der Beispielausgabe auf dem Übungsblatt aus.

Nur stellt sich mir eine Frage: In der Methode selectionSort der Klasse SomeUtilities habe ich folgende for Schleife:
Java:
for(int i=0; i<a.length; i++){/*
		int min = i;
		for(int j=i+1; j<a.length; j++){
			if(a[i].compareTo(a[j])==1){
				min = j;
			}
		}*/
		Arrays.Sort(a);
	}
Ich möchte nicht zu viel von meinem Programm zeigen, da ich es ja abgeben muss. Ich rufe also die compareTo Methode der Klasse Preis auf. Dort habe ich dann einfach hingeschrieben: return 1, falls Objekt ... größer als Objekt ...
Nun ja, ich habe die forSchleife auskommentiert, sodass die compareTo Methode überhaupt nicht aufgerufen wird. Im Moment bekommt mein Programm bzw. die Methode selectionSort lediglich das Objekte-Array a und sortiert dies anscheinend korrekt. Eigentlich brauche ich doch dann gar keine compareTo Methode, bzw. meine Frage wäre nun:

Was macht Arrays.Sort()?
 

Volvagia

Top Contributor
Sorts the specified array of objects into ascending order, according to the natural ordering of its elements. All elements in the array must implement the Comparable interface. Furthermore, all elements in the array must be mutually comparable (that is, e1.compareTo(e2) must not throw a ClassCastException for any elements e1 and e2 in the array).

Mit deutschen Worten, es wird so sortiert wie es deine compareTo vorgibt.
 

XHelp

Top Contributor
Was macht Arrays.Sort()?
Vermutlich einen Compiler-Fehler verursachen, da Sort groß geschrieben ist. Was die Array.sort-Methode macht, steht eigentlich in den Javadocs.
Aber es macht kein Sinn diese in einer Schleife aufzurufen.

Ich denke mal, dass es eher deine Aufgabe ist SelectionSort selber zu implementieren und nicht einfach Arrays.sort aufrufen.
 

XHelp

Top Contributor
Arrays.sort gibt es ja, aber wo kommt denn selectionSort her?
Arrays.sort verwendet glaube ich im Moment QuickSort und ist stabil. Also sieht es für mich so aus, als müsstest du selber SelectionSort implementieren.
 
Java:
static void selectionSort(){
for(int i=0; i<a.length; i++){/*
        int min = i;
        for(int j=i+1; j<a.length; j++){
            if(a[i].compareTo(a[j])==1){
                min = j;
            }
        }*/
        Arrays.Sort(a);
    }
}
Das ist ein Teil meiner Klasse SomeUtilities. Wobei die for-Schleife ausgeklammert ist.

In der Klasse Preis steht ein Konstruktor, für die Speicherung der Menge und des Gesamtpreises.

Java:
class Preis implements Comparable<Preis>{
  //Konstruktor, Methode zur Berechnung des Stückpreises usw.
  public int compareTo(Preis obj){
    //wenn stückpreis()>obj.stückpreis, dann gib 1 zurück. 
  }
}
Meine Idee war eben folgende: Die compareTo Methode der Klasse Preis sollte aus der Methode selectionSort aus der Methode SomeUtilities aufgerufen werden und schauen (nach dem elementarsten Schema des Sortierens), ob es eine höheren Stückpreis gibt. Wenn ja, dann soll dieser das Minimum sein, wenn nicht, dann ist er das Minimum. Daher die zwei for-Schleifen in der Methode selectionSort.
 

Volvagia

Top Contributor
Aber alles was du machst ist a.length-mal das Array zu sortieren. ^^ Und min a.length-mal in einer Schleife zu berechnen ohne es danach zu benutzen.
 
Genau, dass die Schleife sinnlos ist, habe ich irgendwie auch bemerkt. Also habe ich Array.sort(a) herausgezogen:

Java:
class SomeUtilities{
 / /...
 static void selectionSort(){
        Arrays.Sort(a);
 }
}
Und so klappt es seltsamerweise. Aber das kann doch nicht die Lösung sein. Wenn der Satz im Übungsblatt heißt:
Zum Sortieren werden die Methoden selectionSort und Arrays.sort verwendet (aus der Java-Klassenbibliothek). SelectionSort hatten wir übrigens in der Vorlesung, und läuft nach dem Prinzip meiner for-Schleife ab.

Was mich eben wundert, warum sortiert Arrays.sort nach dem Stückpreis, und nicht einfach der Menge oder dem Gesamtpreis? Der Verdacht ist ja bei mir da, dass mein Programm die Vorgaben erfüllt, aber verstehen tu ich es leider nicht.
 

Volvagia

Top Contributor
Ganz einfach: Du hast es in der Methode compareTo so befohlen. Da aber vermutlich keiner hier in der Vorlesung war, können wir es dir auch nicht genauer sagen. Du musst uns mitteilen können, wo dein Problem liegt. Wenn du es aber selbst nicht weißt, da du garnicht weißt was du zu tun hast, können wir dir leider auch nicht weiter helfen. :bahnhof:

btw. wird das Array nicht per Methodenaufruf übergeben? Wäre für imho eine Util-Klasse üblicher.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
L Insertion Sort bei zweidimensionalem Array Java Basics - Anfänger-Themen 7
KogoroMori21 Textdatei einlesen im Array (Selection Sort Algorithmus) Java Basics - Anfänger-Themen 3
S Methoden Sort Array Java Basics - Anfänger-Themen 9
U Methoden Zweidimensionales Array mit Arrays.sort sortieren? Java Basics - Anfänger-Themen 22
C OOP array Sortieren ohne den sort Befehl Java Basics - Anfänger-Themen 10
S int-Array mittels Arrays.sort() in einer Schleife sortieren. Java Basics - Anfänger-Themen 2
T array.sort mit zwei Kriterien Java Basics - Anfänger-Themen 8
S Fehler bei Arrays.sort(array) - Methode!? Java Basics - Anfänger-Themen 3
B 2 dimensionales Array: Selection Sort Java Basics - Anfänger-Themen 4
P Array.sort // Arrays ausgeben Java Basics - Anfänger-Themen 21
I Selection-Sort // Array *help* Java Basics - Anfänger-Themen 2
H Bubble sort array Java Basics - Anfänger-Themen 12
U Array.sort auf variable Array-Größe anwenden Java Basics - Anfänger-Themen 3
G float-Array _ohne_ Arrays.sort sortieren Java Basics - Anfänger-Themen 5
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben