vereinfachtes Wörterbuch in java modellieren

zDieTaschenlampe

Aktives Mitglied
Hallo,
da ich in Sachen modellieren noch nicht so stark bin und Übung bekanntlich den Meister macht, hab ich mir lauter Modellierungsaufgaben aus dem Netz gesucht und bin auf eine gestoßen, die scheinbar einfach aussah, aber mich jetzt doch vor paar Problemen setzt. Es geht also um ein Wörterbuch. Es soll dabei aber eine Textdatei eingelesen ( bisschen verwirrend, hab ich noch nichts zu, aber sollte gehen) werden , in der eben die Wörterpaare von Startsprache und Zielsprache in einer geeigneten Datenstruktur alphabetisch geordnet (Startsprache soll alphabetisch geordnet sein). Dazu habe ich einfach TreeSet benutzt, das alles alphabetisch korrekt anordnet. Hab jetzt auch die Methoden print, print(letter), translate (word ), translate (sentence) zu implementieren und das hab ich auch mehr oder weniger erfolgreich. Hab eigentlich, falls ich den Textdateileser selber hinbekommen, nur 2 Probleme/ Fragen:

1. Modellierung : Ich hab jetzt nur eine Dictionary Class und nehme die Textdatei Wörter als String, weil damit einfacher zu arbeiten ist und die Methoden einfach zu implementieren sind. Aber würdet ihr bzw sollte man eine Klasse für die Wörter haben ? Wenn ja, gäbe es dann auch eine Möglichkeit auf die ganzen String Methoden zuzugreifen wie z. Bsp .toLowerCase .charAt(i) etc weil die bräuchte ich. Hatte nämlich zuerst eine Klasse dafür, aber wusste nicht, wie das geht

2. Findet ihr meine gewählte Datenstruktur die sinnvollste und geeignetste dafür oder gäbe es was besseres ? Hab nämlich das Problem, dass ich nicht weiß, wie ich bei einem gleichen key ( also dem gleichen Wort aus der Startsprache) mehrere Values ( Übersetzungen) zuordnen kann. Also als Bsp Startsprache wäre "klein" und ich füg dem Wörterbuch jetzt in 3 Schritten für klein tiny, small. little hinzu. Dann möchte ich bei print später, wenn das klein geprintet wird auch alle 3 Übersetzungen in einer Zeile daneben haben. Ist das irgendwie realisierbar ? Oder hat wer eine Lösung dafür.

Falls ihr meine Code dazu sehen wollt, kann ich auf Anfrage gerne auch reinschicken, aber vielleicht klappt es ja auch so ? Wäre um jegliche Hilfe dankbar
 

mihe7

Top Contributor
Wege gibt es viele. Wozu brauchst Du denn toLowerCase etc.? Gibt es einen Grund dafür, dann kann es z. B. sinnvoll sein, eine Wort-Klasse zu basteln. Ansonsten halte ich das persönlich für Overkill - aber das ist auch eine "Glaubensfrage".

Ein Starter:
Java:
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Dictionary {
    private static final List<String> NONE = new ArrayList<>();
    private Map<String, List<String>> words = new HashMap<>();

    public void add(String word, String translation) {
        List<String> translations = words.computeIfAbsent(word, w -> new ArrayList<>());
        translations.add(translation);
    }

    public List<String> getTranslations(String word) {
        return Collections.unmodifiableList(words.getOrDefault(word, NONE));
    }
}
 

zDieTaschenlampe

Aktives Mitglied
Wege gibt es viele. Wozu brauchst Du denn toLowerCase etc.? Gibt es einen Grund dafür, dann kann es z. B. sinnvoll sein, eine Wort-Klasse zu basteln. Ansonsten halte ich das persönlich für Overkill - aber das ist auch eine "Glaubensfrage".

Ein Starter:
Java:
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Dictionary {
    private static final List<String> NONE = new ArrayList<>();
    private Map<String, List<String>> words = new HashMap<>();

    public void add(String word, String translation) {
        List<String> translations = words.computeIfAbsent(word, w -> new ArrayList<>());
        translations.add(translation);
    }

    public List<String> getTranslations(String word) {
        return Collections.unmodifiableList(words.getOrDefault(word, NONE));
    }
}

Ich hab es so bisher :

Code:
import java.util.Map;
import java.util.TreeMap;

import edu.kit.informatik.Terminal;

public class Dictionary {

    Map<String, String> dictionary = new TreeMap<String, String>();

    private static boolean isEnabled = true;

    public void add(String germanWord, String translatedWord) {
        dictionary.put(germanWord, translatedWord);
    }

    public boolean remove(String word) {
        for (String i : dictionary.keySet()) {
            if (i.equals(word)) {
                dictionary.remove(word);
                return true;
            }
        }
        return false;

    }

    
    eachten !public void print() {
        if (dictionary.size() == 0) {
            Terminal.printError("");
        }
        for (String i : dictionary.keySet()) {
            Terminal.printLine(i + " - " + dictionary.get(i));
        }
    }

    public void print(char letter) {

        if (dictionary.size() == 0) {
            Terminal.printError("");
        }

        for (String i : dictionary.keySet()) {
// bei print d wird Groß und Kleinschreibung ignoriert laut Aufgabe z Bsp und deswegen muss ich alle wörter mit großem und kleinem d überprüfen
            if (i.toLowerCase().charAt(0) != letter || i.toUpperCase().charAt(0) != letter) {
                Terminal.printError("");
                break;
            } else if (i.toLowerCase().charAt(0) == letter || i.toUpperCase().charAt(0) == letter) {
                Terminal.printLine(i + " - " + dictionary.get(i));
            }
        }
    }

    
    public void translate(String word) {
        for (String i : dictionary.keySet()) {
            if (i.equals(word)) {
                Terminal.printLine(dictionary.get(i));
            }
        }
    }

    public void translateSentence(String sentence) {
        String[] sentenceSplitted = sentence.split(" ");
        String newSent = "";
        for (int j = 0; j < sentenceSplitted.length; j++) {
            for (String i : dictionary.keySet()) {
                if (sentenceSplitted[j].equals(i)) {
                    newSent += dictionary.get(i) + " ";
                }
            }
        }
        Terminal.printLine(newSent);
    }

    public void quit() {
        isEnabled = !isEnabled;
    }

Kann ich deine Methode für die Duplikaten values auch auf meinen Code anwenden ? Mir fällt nämlich nur, dass bei der translate Methode alle entsprechenden Überstzungen mitausgegeben werden und bei der translate (sentence) das gleiche nur mit Sätzen
 

mihe7

Top Contributor
Klar, die TreeMap ist ja nur eine andere Implementierung der Map. Es wird dann ein Wort nicht auf ein übersetztes Wort sondern auf eine Liste von übersetzten Wörtern abgebildet.
 

zDieTaschenlampe

Aktives Mitglied
Wege gibt es viele. Wozu brauchst Du denn toLowerCase etc.? Gibt es einen Grund dafür, dann kann es z. B. sinnvoll sein, eine Wort-Klasse zu basteln. Ansonsten halte ich das persönlich für Overkill - aber das ist auch eine "Glaubensfrage".

Ein Starter:
Java:
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Dictionary {
    private static final List<String> NONE = new ArrayList<>();
    private Map<String, List<String>> words = new HashMap<>();

    public void add(String word, String translation) {
        List<String> translations = words.computeIfAbsent(word, w -> new ArrayList<>());
        translations.add(translation);
    }

    public List<String> getTranslations(String word) {
        return Collections.unmodifiableList(words.getOrDefault(word, NONE));
    }
}

Gibt es keine simplere Möglichkeit ? Weil ich versteh noch nicht mal alles. Angefangen wieso du eine statitsche finale Liste erzeugst
Dann die Methoden .computeIfAbsent ?
Dann was macht w -> new ArrayList
etc

Gibt es nicht eine andere Möglichkeit. die auch in mein Schema vom Still passt. Kann auch simple und schlechte Laufzeit haben, aber ich möchte es auch verstehen
 

mihe7

Top Contributor
Der Pfeil (->) ist die Java-Notation für Lambda-Ausdrücke (=anonyme Funktionen). Man kann das auch ohne Lambdas und ohne computeIfAbsent schreiben:
Java:
    public void add(String word, String translation) {
        List<String> translations = words.get(word);
        if (translations == null) {
            translations = new ArrayList<>();
            words.put(translations);
        }
        translations.add(translation);
    }

Angefangen wieso du eine statitsche finale Liste erzeugst
static final verwendet man in Java für Konstanten. NONE ist somit einfach eine Konstante, die mit einer leeren Liste belegt wird. Damit muss nur einmalig die Liste erzeugt werden. Würde man dagegen
Java:
    public List<String> getTranslations(String word) {
        return Collections.unmodifiableList(words.getOrDefault(word, new ArrayList<>()));
    }
schreiben, würde jedesmal, wenn ein Wort nicht gefunden wurde, eine neue, leere Liste erzeugt. Collections.unmodifiableList sorgt dafür, dass die zurückgegebene Liste nicht verändert werden kann.

Wenn Dir alles egal ist, kannst Du die zweite Methode auch einfach so schreiben:
Java:
    public List<String> getTranslations(String word) {
        List<String> translations = words.get(word);
        if (translations == null) {
            translations = new ArrayList<>();
        }
        return translations;
    }
 

zDieTaschenlampe

Aktives Mitglied
Der Pfeil (->) ist die Java-Notation für Lambda-Ausdrücke (=anonyme Funktionen). Man kann das auch ohne Lambdas und ohne computeIfAbsent schreiben:
Java:
    public void add(String word, String translation) {
        List<String> translations = words.get(word);
        if (translations == null) {
            translations = new ArrayList<>();
            words.put(translations);
        }
        translations.add(translation);
    }


static final verwendet man in Java für Konstanten. NONE ist somit einfach eine Konstante, die mit einer leeren Liste belegt wird. Damit muss nur einmalig die Liste erzeugt werden. Würde man dagegen
Java:
    public List<String> getTranslations(String word) {
        return Collections.unmodifiableList(words.getOrDefault(word, new ArrayList<>()));
    }
schreiben, würde jedesmal, wenn ein Wort nicht gefunden wurde, eine neue, leere Liste erzeugt. Collections.unmodifiableList sorgt dafür, dass die zurückgegebene Liste nicht verändert werden kann.

Wenn Dir alles egal ist, kannst Du die zweite Methode auch einfach so schreiben:
Java:
    public List<String> getTranslations(String word) {
        List<String> translations = words.get(word);
        if (translations == null) {
            translations = new ArrayList<>();
        }
        return translations;
    }

Danke für deine Erklärung, aber inwiefern kombinierst du nun die ursprüngliche map mit der Liste ? Ich versuche das gerade für mich umzubauen ( du siehst ja oben meinen Stand ohne Liste und die Methoden die ich brauche). Kann ich kleine Änderungen machen oder muss ich alles ändern ? Vielleicht könntest du mir ja beim Umbauen der Methoden helfen

Edit : Hab jetzt erst gesehen, dass du mir sogar ein Beispiel gezeigt hast und war von deiner Namensgebung confused, aber ich danke dir. Ich versuche mein bestes Alleine, aber vielleicht komm ich morgen oder irgendwann doch auf dich zurück!
 

zDieTaschenlampe

Aktives Mitglied
Der Pfeil (->) ist die Java-Notation für Lambda-Ausdrücke (=anonyme Funktionen). Man kann das auch ohne Lambdas und ohne computeIfAbsent schreiben:
Java:
    public void add(String word, String translation) {
        List<String> translations = words.get(word);
        if (translations == null) {
            translations = new ArrayList<>();
            words.put(translations);
        }
        translations.add(translation);
    }


static final verwendet man in Java für Konstanten. NONE ist somit einfach eine Konstante, die mit einer leeren Liste belegt wird. Damit muss nur einmalig die Liste erzeugt werden. Würde man dagegen
Java:
    public List<String> getTranslations(String word) {
        return Collections.unmodifiableList(words.getOrDefault(word, new ArrayList<>()));
    }
schreiben, würde jedesmal, wenn ein Wort nicht gefunden wurde, eine neue, leere Liste erzeugt. Collections.unmodifiableList sorgt dafür, dass die zurückgegebene Liste nicht verändert werden kann.

Wenn Dir alles egal ist, kannst Du die zweite Methode auch einfach so schreiben:
Java:
    public List<String> getTranslations(String word) {
        List<String> translations = words.get(word);
        if (translations == null) {
            translations = new ArrayList<>();
        }
        return translations;
    }

Ich bräuchte doch nochmal deine Hilfe bezüglich paar Dingen :

Bezüglich der print Methode, hab ich das jetzt so umgesetzt :
Code:
public void print() {
        if (dictionary.size() == 0) {
            Terminal.printError("");
        }
        for (String i : dictionary.keySet()) {
            Terminal.printLine(i + " - " + dictionary.get(i).toString().replace("[", "").replace("]", "")); // Da ich ja eine Liste von Wörtern printe, kommen die als [word, word1]
            // deswegen diese replace Methode. Gibt es dafür eine schönere Methode ?
        }
    }
    
    2. problem ist dass bei mehreren Übersetzungen die Ausgabe so brauche Meer - ocean,sea aber ich kriege Meer - ocean, sea

Bei der translate ( word) Methode das gleiche wie bei print. Also statt ocean, sea brauche ich ocean,sea (Ohne dieses Leerzeichen) und meine größte Schwierigkeit ist die translate Sentence Methode, denn hier muss jede Möglichkeit zeilenweise übersetzt werden, aber kannst du mir vielleicht zeigen wie ? Mein Code gerade :
Code:
public void translateSentence(String sentence) {
        String[] sentenceSplitted = sentence.split(" ");
        String newSent = "";
        for (int j = 0; j < sentenceSplitted.length; j++) {
            for (String i : dictionary.keySet()) {
                if (sentenceSplitted[j].equals(i)) {
                    newSent += dictionary.get(i) + " ";
                }
            }
        }
        Terminal.printLine(newSent);
    }
    
    liefer bei translate("Das Meer") : The - ocean, sea aber brauche
    The sea
    The ocean
    
    Ist das realisierbar ?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T OOP Wörterbuch NullPointerException Java Basics - Anfänger-Themen 4
Private Void Java-"Wörterbuch"? Java Basics - Anfänger-Themen 3
S Ideenpool -> Englisch - Deutsch Wörterbuch Java Basics - Anfänger-Themen 16
I Frage wegen Wörterbuch Programmierung Java Basics - Anfänger-Themen 13
G Wörterbuch einbinden Java Basics - Anfänger-Themen 4
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

Ähnliche Java Themen

Neue Themen


Oben