Collections Java Wörter in String zählen und geordnet ausgeben

Braniac92

Mitglied
Hey Leute,

Ich würde gerne aus einem String zählen wieoft ein Wort vorkommt und dann Sortiert die 10 häufigsten Wörter rausgeben.

Der String ist folgendermaßen aufgebaut:

String s = "a, b, a, b, c, d, c, a";

Nun suche ich eine Möglichkeit aus diesem zu zählen wie oft ein Wort vorkommt und dann zurückzugeben, wieoft ein Wort vorkommt.
Also etwas ind er Art:

a = 3, b = 2, c = 2, d = 1

Welche Strategie würde sich dafür am besten eignen? Oder gibt es schon funktionen, die das machen?
Wäre für Hilfe sehr dankbar.
 
X

Xyz1

Gast
Mappen würd ich eigentlich nicht im eigentlichen Sinne:
Java:
        int[] array = new int[256];
        String s = "a, b, a, b, c, d, c, a";
        for (int i = 0; i < s.length(); i += 3) {
            array[s.charAt(i)]++;
        }
        for (int i = 0; i < array.length; i++) {
            if (array[i] > 0) {
                System.out.println((char) i + " " + array[i]);
            }
        }

Code:
a 3
b 2
c 2
d 1

Könntet Ihr mir bitte die Java 8 - 9 Lösung geben / zeigen? (Lambda/Funktional) Bin da etwas schwerfällig
 

Braniac92

Mitglied
Ok vielen Dank schonmal.

Ich hab mir das Vorgehen so überlegt.

1) Ich splitte den String beim komma und erhalte dann ein Stringarray mit allen Wörtern.
2) Erstelle mit eine neue Klasse "Player" die die Werte String und In übergeben bekommen.
3) ich erstelle linkedList<Player> in der ich dann sowohl den Namen als auch die Zahl übergebe
4) Dann gehe ich für jedes Wort eine Schleife durch (prüfe vorher schon ab, ob ich das Wort schon geprüft habe, zähle über die Wörte und füge sie als neuen "Player" in die Liste hinzu.
5) Wenn ich fertig bin sortiere ich die Liste nach den Int werten (nur wie?) und dann habe ich mein ergebnis.

Ist dieses Vorgehen gut? Bzw mache ich mir damit zuviel Arbeit?

EDIT: Ok das Wie habe ich.. habe über Collections.sort sortiert. Nun eher die Frage, ob das Vorgehen so sinnvoll ist oder ich es auch hätte "besser" lösen können.
 
Zuletzt bearbeitet:

Braniac92

Mitglied
Also ich möchte Wörter nach Zahlen sortieren. folgende Umsetzung müsste funktionieren:

Java:
LinkedList<Player> p = new LinkedList<Player>();
        p.add(new Player("a", 10));
        p.add(new Player("b", 2));
        p.add(new Player("c", 6));
        p.add(new Player("d", 1));
        p.add(new Player("e", 7));

        System.out.println(p);
       
        Collections.sort(p, new Comparator<Player>(){
               @Override
               public int compare(Player o1, Player o2){
                    if(o1.getTore() < o2.getTore()){
                       return 1;
                    }
                    if(o1.getTore() > o2.getTore()){
                       return -1;
                    }
                    return 0;
               }
            });
       
   
        System.out.println(p);

Kurze Erklärung dazu:
Ein Player besteht aus einem Wort und einer Zahl.
Bei der Collections habe ich 1 und -1 vertauscht, um eine reverseSortierte Liste zuerhalten. So bekomme ich an erster Stelle das Wort mit der höchsten Anzahl.
 
X

Xyz1

Gast
1) Ich splitte den String beim komma und erhalte dann ein Stringarray mit allen Wörtern.

- korrekt. Der Delimiter wäre ", "

2) Erstelle mit eine neue Klasse "Player" die die Werte String und In übergeben bekommen.

- korrekt, der bekommt einen Split

3) ich erstelle linkedList<Player> in der ich dann sowohl den Namen als auch die Zahl übergebe

- könnte man so machen, um erst einmal alle Splits und Zahlen zu sammeln

4) Dann gehe ich für jedes Wort eine Schleife durch (prüfe vorher schon ab, ob ich das Wort schon geprüft habe, zähle über die Wörte und füge sie als neuen "Player" in die Liste hinzu.

- dann wird die Liste ja endlos - und das Programm hält nicht an

5) Wenn ich fertig bin sortiere ich die Liste nach den Int werten (nur wie?) und dann habe ich mein ergebnis.

- was stellen denn die Zahlen für Daten dar???

Java:
/**
*
* @author
*/
public class StringsAufteilen {

    public static void main(String[] args) {
        String s = "a, b, a, b, c, d, c, a";
        String[] split = s.split(", ");
        StringUndZahl[] suz = new StringUndZahl[split.length];
        for (int i = 0; i < split.length; i++) {
            suz[i] = new StringUndZahl();
            suz[i].s = split[i];
        }

        for (String string : split) {
            for (StringUndZahl stringUndZahl : suz) {
                if (string.equals(stringUndZahl.s)) {
//                    for (StringUndZahl stringUndZahl1 : suz) {
//                        if (string.equals(stringUndZahl1.s)) {
//                            stringUndZahl1.i++;
//                        }
//                    }
                    stringUndZahl.i++;
                }
            }
        }

        Arrays.sort(suz, new Comparator<StringUndZahl>() {
            @Override
            public int compare(StringUndZahl o1, StringUndZahl o2) {
                return o2.i - o1.i; // nicht so machen
            }
        });
        for (StringUndZahl stringUndZahl : suz) {
            System.out.println(stringUndZahl);
        }
    }
}

class StringUndZahl {

    String s;
    int i;

    @Override
    public String toString() {
        return "StringUndZahl{" + "s=" + s + ", i=" + i + '}';
    }
}


Code:
StringUndZahl{s=a, i=3}
StringUndZahl{s=a, i=3}
StringUndZahl{s=a, i=3}
StringUndZahl{s=b, i=2}
StringUndZahl{s=b, i=2}
StringUndZahl{s=c, i=2}
StringUndZahl{s=c, i=2}
StringUndZahl{s=d, i=1}
Das würd mir mein Chef um die Ohren haun.

(Zusätzlich: Bitte SSCCE...)
 

klauskarambulut

Bekanntes Mitglied
Wenn man schonmal was von modernem Java gesehen hat…
Java:
import java.util.Comparator;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;

public class CountWords {

    public static void main(String[] args) {
        String s = "a, b, a, b, c, d, c, a, d, d, d,, , d";

        Stream.of(s.split(","))
                //Strings zuschneiden und leere Strings entfernen
                .map(String::trim).filter(str -> !str.isEmpty())

                //Histogram erstellen
                .collect(Collectors.groupingBy(Function.identity(),
                        Collectors.mapping(i -> 1, Collectors.summingInt(sum -> sum.intValue()))))

                //Einträge nach Anzahl absteigend sortieren
                .entrySet().stream()
                .sorted(Comparator.comparing((Map.Entry<String, Integer> e) -> e.getValue()).reversed())

                //Ergebnis ausgeben
                .forEach(System.out::println);
    }
}
 
X

Xyz1

Gast
Wenn man schonmal was von modernem Java gesehen hat…

Ist natürlich völlig unlegitim/illegitim(/unangemessen)/unangebracht/kontraproduktiv und deplatziert. Er wollte gerne eigene Klasse/Objekt (mit String und Zahl) haben. Nichts anderes als mein erster Beitrag macht dein Spaghetticode da. Aber schön, dass du Java 8 "kannst".

Und "du" hast Map für Buchstaben missbraucht. Das ist nicht modern - sondern langsam.
 
Zuletzt bearbeitet von einem Moderator:

Kababär

Top Contributor
Könntet Ihr mir bitte die Java 8 - 9 Lösung geben / zeigen? (Lambda/Funktional) Bin da etwas schwerfällig

Ist natürlich völlig unlegitim/illegitim(/unangemessen)/unangebracht/kontraproduktiv und deplatziert.[...]
Aber schön, dass du Java 8 "kannst".

Ok.

Und "du" hast Map für Buchstaben missbraucht. Das ist nicht modern - sondern langsam.

Ich glaube nicht, dass der Unterschied so gigantisch ist.
 

Flown

Administrator
Mitarbeiter
Generell war die Aufgabenstellung "Wörter" zu zählen, darum ist hier auch eine Map die richtige Wahl.
Ich "verbessere" die Java 8 Lösung von @klauskarambulut ein wenig, denn:
- Pattern kann schon einen Stream adhoc erzeugen
- Collector kann eingespart werden
- Spezielle Comparatoren gibt es für Entry-Klasse
- die 10 meistgezähltesten Worte sollten ausgegeben werden
- richtiges verwenden von terminal operations
Java:
Pattern.compile(",\\s*").splitAsStream(s).filter(str -> !str.isEmpty())
    .collect(Collectors.groupingBy(Function.identity(), Collectors.summingInt(str -> 1))).entrySet().stream()
    .sorted(Entry.<String, Integer>comparingByValue().reversed()).limit(10).forEachOrdered(System.out::println);
Wie man das jetzt handhabt, ob man hier Objekte verwendet oder Entry der Map, sei jetzt dem Anwendungsfall/Projekt überlassen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
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
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8
Tw1Z Erste Schritte Sort in java Java Basics - Anfänger-Themen 2
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben