Sring ArrayList Manuel sortieren

Koori

Mitglied
hallihallo alle zusammen!

ich brauche Hilfe beim sortieren von meiner Array liste, jedoch DARF ich die String sort() methode NICHT benutzen. brauche wirklich Hilfe!!

ich hab unten meinen quelltext nur mal so ;)

Java:
import java.util.ArrayList; 
import java.util.Iterator;
public class WordList{ 
    private ArrayList<String> words = new ArrayList(); 
    public WordList(){ 

    } 

    public void addWord(String word){  
        words.add(word);
    } 

    public void printWords(int i){  
        
        switch (i){
            case 1:
                        for (int index = 0; words.get(index) != null; index++ ){
                            System.out.println(words.get(index));
                        }
            
            case 2 :
                        for (String word : words){
                         System.out.println(word);
                        }
            
            case 3 :
                     
                        while ( i < words.size()){
                            System.out.println(words.get (i));
                            
                            i++;
                        }
                        
                        
            case 4 :
                        Iterator entries = words.iterator();
                        
                        while( entries.hasNext()){
                            Object element = entries.next();
                        System.out.println(element);
                        }
        }
        
        // Implementieren Sie die verschiedenen Schleifenarten 
        // Verwenden Sie das switch-Konstrukt (Buch Seite 554-555) 
        // i=0: for-Schleife 
        // i=1: for-each-Schleife 
        // i=2: while-Schleife 
        // i=3: iterator-Schleife  
    } 

    public int numberOfWords(){   
        return words.size();

        //  int rückgabe wert!!!
        //Die komplette Anzahl Wörter wird als Rückgabewert  
        // zurückgeliefert 
    } 

    public int numberOfCharactersOfWord(int i){  

        return words.get(i).length();

    } 

    public int numberOfCharactersInList(){ 

        String list = "";

        for (String word : words){
            list += word;
        }
        return list.length();
    }

}
 
F

Firephoenix

Gast
String hat doch gar keine sort()-Methode, meinst du evtl Collections.sort()?

In deinem Code fehlt auch noch die entsprechende Methode die du benutzt zum sortieren, hast du schon einen Ansatz?

Und nach welchem Schema sollst du sortieren?
Möglich wäre z.B. eine Alphabetische sortierung, oder eine Sortierung nach der Wortlänge etc.

Gruß
 
G

Gast2

Gast
Von sortieren ist da nichts zu sehn, was hast du schon versucht? Welchen Sortieralgorithmus willst du implementieren?
 

Koori

Mitglied
@FirePhoenix: oh sorry jaja ich wollte es alphabetisch sortieren... hab aber keinen blassen schimmer wie es geht.

Mein Dozent hat gesagt das ich keine, von Java vorgefertigte sortier methode benutzen darf :(



@EikeB:

ich hab erstmal gedacht das man eine > oder < verwenden kann und den String wie ein int behandeln



Könntet ihr mir weiterhelfen ???
 
Zuletzt bearbeitet:
G

Gast2

Gast
Sortierverfahren ? Wikipedia
Da findest du eine Liste an Sortierverfahren, schau dir ein paar davon an, such dir den aus der dir am besten gefällt, und implementier den. Wenn du da ne Frage zu hast dann helfen wir dir hier gern weiter.
Deine Hausaufgaben macht dir hier aber niemand :)
 
F

Firephoenix

Gast
Grundsätzlich benötigst du zum sortieren 2 Dinge:
-Eine Methode die 2 Elemente vergleicht
-Einen Sortieralgorythmus

Möglich wäre also so etwas wie eine eigene vereinfachte compare-Methode:

Java:
/**
*Gibt true zurueck wenn der erste String hinter dem 2. einsortiert werden muss
*/
public boolean isFirstStringGreaterAsSecondString(String first, String second);

Hast du eine Idee wie du so etwas implementieren könntest? (charweise die Strings vergleichen z.B.?)

Dann brauchst du einen Algorythmus zum sortieren, relativ einfach dürfte es sein mit einer leeren Liste anzufangen, dann ein Wort nach dem anderem einzufügen (add() fügt ja immer am Ende an, also könntest du dir z.b. immer den "kleinsten" String aus deiner startliste rausnehmen und den an die leere liste anhängen).

Wenn du einen Ansatz hast zeig mal her, dann kann man damit weiterarbeiten.

Java:
ich nehme mal an das String.compareTo(String) ebenfalls verboten ist.

Gruß
 

Koori

Mitglied
mein Kopf explodiert !!!

hab mir die wiki Seite angesehen und herausgefunden das ich den "merge sort" benutzen kann. Bin im Moment diesen Code am entziffern den ich bei Stackoverflow gefunden hab.

Java:
/*
 * Sorting methods, implemented using mergesort to sort the array of names
 * alphabetically
 */
public String[] sort(String[] array) {
    // check if the number of elements < 2
    if (array.length > 1) {

        // divide into two smaller arrays
        // determine length of two smaller arrays
        int arrLen1 = array.length;
        int arrLen2 = array.length - arrLen1;

        // populate smaller arrays with elements from initial array
        String[] array1 = new String[arrLen1];
        String[] array2 = new String[arrLen2];

        for (int i = 0; i < arrLen1; i++) {
            array[i] = array1[i];
        }

        for (int i = arrLen1; i < array.length; i++) {
            array[i] = array2[i];
        }

        // now that we have the two halves, we can recursively call sort() on each to sort them
        array1 = sort(array1);
        array2 = sort(array2);

        // three counters are needed to keep track of where we are in the arrays, one for pos in final array, and one for each of the two halves
        // i => pos in main array
        // j => pos in array1
        // k => pos in array2
        int i = 0, j = 0, k = 0;

        while (array1.length != j && array2.length != k) {
            if (array1[i].compareTo(array2[i]) < 0) {
                // copy current element of array1 to final array as it preceeds array2's current element
                array[i] = array1[j];

                // increment the final array so we dont overwrite the value we just inserted
                i++;
                // increment array1 which we took the element from so we dont compare it again
                j++;
            }
            // If the element in array2 preceeds the element in array1

            else {
                // copy current element of array1 to final array as it preceeds array1's current element
                array[i] = array2[j];
                // increment the final array so we dont overwrite the value we just inserted
                i++;
                // increment array2 which we took the element from so we dont compare it again
                k++;
            }
        }

        // at this point one of the sub arrays have been exhausted, and no more elements to compare
        while (array1.length != j) {
            array[i] = array1[j];
            i++;
            j++;
        }

        while (array2.length != k) {
            array[i] = array2[k];
            i++;
            k++;

        }
    }

    return array;
}

programmiere in java erst seit knapp 4 wochen, wünschte ich könnte eine vorgefertigte methode wie String.compareTo(String) benutzen...
 
H

hüteüberhüte

Gast
mein Kopf explodiert !!!

hab mir die wiki Seite angesehen und herausgefunden das ich den "merge sort" benutzen kann.

Benutz lieber Selectionsort. Bei merge sort kann zu viel schief gehen.

Weil ich ganz dreist bin und keinen Anstand kenne, werde ich das gleich einfach mal machen :D
 

Koori

Mitglied
hab gerade gesehn das es die Strings nur nach länge sortiert :/

ein tutorial vom Sortieren oder irgend ein link wäre gut
oder eine abstrakte Beschreibung des Sortier verfahren
 
G

Gast2

Gast
Nein, Selectionsort ist nur ein Verfahren um Elemente zu sortieren, was genau sortiert wird bestimmt die compare Methode. Du kannst also nicht nur Strings der Länge nach sortieren.
 

Bernd Hohmann

Top Contributor
Bubblesort, ist schnell implementiert.

Hier sortiere ich Mailhosts nach Priorität.

Code:
				boolean blnNotSorted;
				do {
					blnNotSorted = false;
					for (int j = 0; j < records.length - 1; j++) {
						MXRecord mxrecord1 = (MXRecord) records[j];
						MXRecord mxrecord2 = (MXRecord) records[j + 1];
						if (mxrecord1.getPriority() > mxrecord2.getPriority()) {
							records[j] = mxrecord2;
							records[j + 1] = mxrecord1;
							blnNotSorted = true;
						}
					}
				} while (blnNotSorted);
 
H

hüteüberhüte

Gast
Java:
package javaforum;

import java.util.Arrays;
import java.util.Collections;
import java.util.List;

/**
 * @author hüte
 */
public class Sortierer {

    public static List<String> sortiere(List<String> lst) { // Selectionsort, nach Länge aufsteigend
        for (int i = 0; i < lst.size() - 1; i++) {
            int kürzestes = i;
            for (int j = i + 1; j < lst.size(); j++) {
                if (lst.get(j).length() < lst.get(kürzestes).length()) {
                    kürzestes = j;
                }
            }
            if (kürzestes != i) {
                String temp = lst.get(i);
                lst.set(i, lst.get(kürzestes));
                lst.set(kürzestes, temp);
            }
        }
        return lst;
    }

    public static void main(String[] args) { // die main()-Methode
        for (int i = 0; i < 10; i++) {
            List<String> lst = Arrays.asList("55555", "4444", "333", "22", "1");
            Collections.shuffle(lst);
            sortiere(lst);
            System.out.println(lst);
        }
    }
}

Der Länge nach wird sortiert. sortiere könnte man auch generisch machen, so dass sie z.B. alle Listen Comparable-implementierender Klassen sortiert
 
Zuletzt bearbeitet von einem Moderator:
Ähnliche Java Themen
  Titel Forum Antworten Datum
G JTextArea mit Daten aus Datenbank ( im Wert Sring ) befüllen Java Basics - Anfänger-Themen 3
krgewb ArrayList allgemein halten Java Basics - Anfänger-Themen 6
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Z Java ArrayList speichert falsche Daten ab bzw. gibt falsche Daten aus? Java Basics - Anfänger-Themen 42
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
W ArrayList und toString Java Basics - Anfänger-Themen 17
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
M 2d ArrayList durchgehen Java Basics - Anfänger-Themen 2
Blkckroll45 Arraylist Java Basics - Anfänger-Themen 6
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
D Arraylist mit Komplexen Datentyp Java Basics - Anfänger-Themen 3
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
volcanos List & ArrayList nach Familiennamen abfragen Java Basics - Anfänger-Themen 57
M static ArrayList in non-static Java Basics - Anfänger-Themen 12
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
S ArrayList Username und passwort mit JTextField eingaben abgleichen Java Basics - Anfänger-Themen 10
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
F Erste Schritte Zahlenreihe von Arraylist in 3erBlöcke sortiert in neue Arraylist Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
J ArrayList add methode selbst programmieren Java Basics - Anfänger-Themen 10
K Erste Schritte Wie schnell ist LinkedHashMap im Vergleich zur ArrayList, wenn alle Entries durchlaufen werden? Java Basics - Anfänger-Themen 47
thobren jtable arraylist Java Basics - Anfänger-Themen 12
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
P Schiebefix - ArrayList überschreibt Daten Java Basics - Anfänger-Themen 3
Zeppi OOP ArrayList Java Basics - Anfänger-Themen 2
P ArrayList Java Basics - Anfänger-Themen 4
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
C ArrayList sortieren nach bestimmten Buchstaben in den Wörtern Java Basics - Anfänger-Themen 13
S Arraylist<Object> mit verschiedenen Objects ausgeben Java Basics - Anfänger-Themen 3
J ArrayList auf bereits vorhanden eintrag prüfen Java Basics - Anfänger-Themen 5
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
L Längstes Element einer ArrayList ausgeben Java Basics - Anfänger-Themen 9
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
M ArrayList in GUI ausgeben Java Basics - Anfänger-Themen 1
J Nur bestimmter Typ aus der ArrayList ausgeben. Java Basics - Anfänger-Themen 9
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
C Sortieren einer ArrayList Java Basics - Anfänger-Themen 2
krgewb ArrayList von ArrayList Java Basics - Anfänger-Themen 2
R ArrayList Problem Java Basics - Anfänger-Themen 6
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
O Namen (mit Umlauten und ß) in einer ArrayList suchen Java Basics - Anfänger-Themen 5
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5
M Letztes Element einer ArrayList Java Basics - Anfänger-Themen 12
B Objektverwaltung mit ArrayList in einer seperaten Klasse Java Basics - Anfänger-Themen 24
I Sortiert eine HashMap nicht gleich wie eine ArrayList? Java Basics - Anfänger-Themen 1
I ArrayList erstellen innerhalb einer Zeile? Java Basics - Anfänger-Themen 3
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
V Collections ArrayList mit Comparator sortieren Java Basics - Anfänger-Themen 16
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
F java.util.ArrayList Java Basics - Anfänger-Themen 3
M ArrayList - Objekt kopieren und ändern Java Basics - Anfänger-Themen 11
M Zugriff auf eine ArrayList in einer anderen Klasse Java Basics - Anfänger-Themen 4
P Arraylist zu einem Array bringen mit Verschachtelung Java Basics - Anfänger-Themen 11
N Methode mit einer Arraylist Java Basics - Anfänger-Themen 106
I ArrayList - Methode zum Speichern eines Eintrags in einer Datei Java Basics - Anfänger-Themen 17
H ArrayList Java Basics - Anfänger-Themen 7
D public ArrayList(Collection<? extends E> c); Java Basics - Anfänger-Themen 2
M JTextField in ArrayList speichern Java Basics - Anfänger-Themen 4
C ArrayList mit return zurückgeben Java Basics - Anfänger-Themen 13
K Zahlenfolge ArrayList Java Basics - Anfänger-Themen 3
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
I Klassen Eine ArrayList<Long>, die sich automatisch sortiert Java Basics - Anfänger-Themen 20
F Array in ArrayList ablegen Java Basics - Anfänger-Themen 3
V ArrayList Java Basics - Anfänger-Themen 1
Z Runden Arraylist Java Basics - Anfänger-Themen 9
X Frage zur einer ArrayList in einer ArrayList Java Basics - Anfänger-Themen 5
F Arraylist als Pfadausgabe Java Basics - Anfänger-Themen 10
L Daten aus ArrayList in Datenbank durchsuchen Java Basics - Anfänger-Themen 5
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
M Problem mit ArrayList Java Basics - Anfänger-Themen 32
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
O Hashmap, ArrayList, LinkedList Java Basics - Anfänger-Themen 7
X Problem mit Arraylist in Arraylist Java Basics - Anfänger-Themen 2
O HashMap - ArrayList Java Basics - Anfänger-Themen 29
M UML-Klassendiagramm ArrayList Java Basics - Anfänger-Themen 1
O ArrayList oberflächig durchsuchen Java Basics - Anfänger-Themen 3
I "\n" aus ArrayList enfernen, aber wie?! Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben