mehrere TreeSets so speichern, dass man sie miteinander vergleichen kann

system.exit

Neues Mitglied
Hallo,

ich versuche ein kleines Demoprogramm zu schreiben, das einen Greedyalgorithmus auf das Set Cover Problem angewendet, zeigt.

Kurze Erklärung:
man hat eine Obermenge, die aus allen Elementen besteht, die in dazugehörigen Untermengen vorkommen. Man soll aus allen Untermengen eine Auswahl finden, sodass jedes Element der Obermenge mindestens einmal abgedeckt ist.
Beispiel:
Obermenge E = {A, B, C}
Untermenge U1 = {A, B}
Untermenge U2 = {B, C}
Untermenge U3 = {A, C}

=> Obermenge E ist abgedeckt durch U1 und U2.

In meinem Programm soll der User die Möglichkeit haben, zu wählen, ob seine Mengen aus chars oder ints besteht. Dann soll er alle Elemente der Obermenge eingeben. Danach werden so lange Untermengen hinzugefügt, bis er fertig ist, woraufhin das Programm eine mögliche Lösung für die Eingabe ausspuckt.

Mein Ansatz:
  • User input durch Scanner
  • Da Scanner Input als Array speichert, wird die Eingabe zuerst in ein TreeSet konvertiert. Dadurch werden Duplikate ignoriert und die Eingabe ist geordnet.
  • Es ist unbekannt, wie viele Untermengen der User eingeben möchte. Daher sollen so lange Untermengen angelegt und gespeichert werden, bis User sagt "fertig".
Meine Probleme:
  • ich glaube, ich überschreibe immer die selbe Untermenge, wenn ich in der Schleife bin, wo der User neue Mengen anlegen kann
  • ich weiß nicht, wie ich überhaupt die Obermenge mit nur einer einzigen Untermenge vergleichen könnte
  • der Iterator für die While-Schleife ab Zeile 94 funktioniert nicht so, wie ich es gern hätte.

Java:
import java.util.Scanner;
import java.util.Set;

/**
 * contains all instructions and interactions with user
 */
public class Instructions {

    public static void instructions() {
        Scanner scan = new Scanner(System.in);

        //Welcome message.
        System.out.println("This is a simple demo of a greedy algorithm for the set cover problem.\n"
                + "Let's get started.\n\n");

        //user instructions: choose which element types (char or int) to use for demo.
        System.out.println("For this application to work, first select which kind of elements your sets will contain.\n"
                + "Press: "
                + "\n"
                + "c \t for CHARACTERS like a, b, c "
                + "\n"
                + "\t\t --- or ---"
                + "\n"
                + "i \t for INTEGERS like -2, 0, 11 \n");

        //use charAt(0) in case user types in more than one symbol
        char elementType = scan.nextLine().toLowerCase().charAt(0);

        //user input should only be 'c' or 'i'. Repeat until input is valid. Not case-sensitive.
        boolean incorrectInput = true;
        while(incorrectInput) {               
            switch  (elementType) {
                case 'c':
                    //user feedback.
                    System.out.println("Your sets will have elements of type CHAR.\n");

                    //user instructions: enter elements for ground set E
                    System.out.println("Please enter all elements that are in the ground set E:\n");

                    //char array that holds user input. Input should be abcd. No spaces or commas as it will also be stored. Improve?
                    char[] inputGroundSet = scan.nextLine().toCharArray();

                    //cast char[] to Character[] for use with convertArrayToTreeSet-Method:
                    Character[] charGroundSetBoxed = new String(inputGroundSet).chars().mapToObj(c -> (char) c).toArray(Character[]::new);

                    //convert the Array to a Set:
                    Set <Character> groundSet = HelperMethods.convertArrayToTreeSet(charGroundSetBoxed);

                    //user feedback. Prints out sorted set without duplicates.
                    System.out.println("The elements in your ground set are: " + groundSet);

                    //set to false to leave while-loop.
                    incorrectInput = false;
                    break;

                case 'i':
                    //TODO do the same with integers.

                    System.out.println("THIS IS A PINK ELEFANT. Not implemented yet.");

                    //set to false to leave while-loop
                    incorrectInput = false;
                    break;

                default:
                    System.out.println("Not a valid option.\n"
                            + "Please type 'c' for characters or 'i' for integers.");

                    //keep scanning until input is valid
                    elementType = scan.nextLine().toLowerCase().charAt(0);
            }
        }


        //conditions for subsets depending on elementType.
        if(elementType == 'c') {
            //user instructions: menu for setting up subsets: new, finish. Cancel would be gth.
            System.out.println("\n\nNow, let's define some subsets.\n"
                    + "Press:"
                    + "\n"
                    + "n\tfor a NEW subset"
                    + "\n"
                    + "\t\t --- or ---"
                    + "\n"
                    + "f\tto FINISH setting up subsets and have covering sets calculated.\n");

            //use charAt(0) in case user types in more than one symbol
            char menu = scan.nextLine().toLowerCase().charAt(0);

            boolean notMenu = true;

            //iterator doesn't work like intended.
            int i = 0;
            while(notMenu) {   
                i++;
                switch (menu) {
                    case 'n':

                        //user instructions: enter elements for current subset
                        //TODO needs to count which subset this is.
                        System.out.println("Please enter all elements that are in subset S" + i + ":\n");

                        //char array that holds user input. Input should be abcd. No spaces or commas as it will also be stored.
                        char[] inputSubset = scan.nextLine().toCharArray();

                        //cast char[] to Character[] for use with convertArrayToTreeSet-Method:
                        Character[] charSubsetBoxed = new String(inputSubset).chars().mapToObj(c -> (char) c).toArray(Character[]::new);

                        //convert the Array to a Set:
                        Set <Character> subset = HelperMethods.convertArrayToTreeSet(charSubsetBoxed);

                        //user feedback. Prints out sorted set without duplicates.
                        //TODO count which subset
                        System.out.println("The elements in Subset are: " + subset);

                        //set to false to leave while-loop.
                        //notMenu = false;
                        break;

                    case 'f':
                        //TODO do the same with integers.

                        System.out.println("THIS IS A PINK ELEFANT.");

                        //set to false to leave while-loop
                        notMenu = false;
                        break;

                    default:
                        System.out.println("Not a valid option.\n"
                                + "Press n or f.");

                        //keep scanning until input is valid
                        menu = scan.nextLine().toLowerCase().charAt(0);
                }
            }
        }else {
            System.out.println("elementType is not c");
        }
    }

}

Java:
import java.util.Set;
import java.util.TreeSet;

public class HelperMethods {
    /**
     * Generic function to convert any Array to a TreeSet (a sorted set without duplicates).
     * Needs casting on primitive data types before use.
     *
     * @param <T>        expected class of the value, e.g. Set <Character> nameOfSet
     * @param array        expected parameter (Scanner stores user input as array)
     * @return            the resulting TreeSet of the arguments in array
     */
    public static <T> Set<T> convertArrayToTreeSet(T array[]) {
        //create empty Set:
        Set <T> treeSet = new TreeSet<>();
        
        //iterate through array and add each element into the set
        for (T t: array) {
            treeSet.add(t);
        }
        
        return treeSet;
    }

}


Wäre super, wenn mir jemand helfen könnte.
 

mihe7

Top Contributor
Zunächst einmal kannst Du char wie int behandeln (ein char ist eine vorzeichenlose 16-bit Ganzzahl), lediglich bei der Ein- und Ausgabe musst Du etwas aufpassen.

Was die Eingabe der Untermengen betrifft: Du möchtest eine Menge von Mengen. Also musst Du auch ein entsprechendes Set verwenden (z. B. Set<Integer> subsets) und ein eingegebenes Subset dort hinzufügen.

Was den Vergleich betrifft: Du könntest eine Kopie der Obermenge anlegen, aus dieser alle Elemente, die in den betreffenden Subsets enthalten sind enternen und abschließend schauen, ob die Kopie der Obermenge leer ist. Umgekehrt kannst Du auch ein neues Set erstellen, das alle betreffenden Subsets zusammenfasst und abschließend per equals mit der Obermenge verglichen wird. Darüber hinaus gibt es auch die containsAll()-Methode, mit der Du prüfen kannst, ob eine Menge alle Elemente einer anderen Menge enthält.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
K Mehrere Werte in einem Switch Case parallel überprüfen Java Basics - Anfänger-Themen 23
S HashMap mehrere Keys zu einem Value Java Basics - Anfänger-Themen 3
T Mehrere if bedingungen ohne & Java Basics - Anfänger-Themen 2
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
MiMa Java Doc mehrere Return Parameter Java Basics - Anfänger-Themen 11
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
Buroto Klassen Mehrere .txt Datein verbienden und anschließend auslisten Java Basics - Anfänger-Themen 10
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
M Mehrere Daten/ Variablen Speichern Java Basics - Anfänger-Themen 9
C mehrere JPanel in ein JFrame bringen Java Basics - Anfänger-Themen 9
L Beim Java Programmstart, mehrere Parameter über die Kommandozeile übergeben Java Basics - Anfänger-Themen 9
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
U Kann man bei Java gleich mehrere Bedingungen prüfen in der If, aber in einem "Satz"? Java Basics - Anfänger-Themen 1
Kotelettklopfer Mehrere Projekte in einem Git verwalten Java Basics - Anfänger-Themen 10
I JAX-RS Mehrere Parameter in Query Java Basics - Anfänger-Themen 3
M mehrere Rückgabenwerte aus Methode Java Basics - Anfänger-Themen 7
A Input/Output Mehrere Csv-Dateien einlesen Java Basics - Anfänger-Themen 2
R Mehrere Buchstaben aus einem String entfernen Java Basics - Anfänger-Themen 1
TimoN11 Java - Eine oder mehrere Eingaben möglich machen Java Basics - Anfänger-Themen 6
M Mehrere Datenbank zugriffe über tomee.xml regeln? Java Basics - Anfänger-Themen 1
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
Ich lerne Java. Methoden Mehrere Methoden mit Punkt Java Basics - Anfänger-Themen 45
M Ausgabe einer Liste welche mehrere Stacks enthält Java Basics - Anfänger-Themen 3
D OOP- Eine Klasse in mehrere Klassen aufteilen Java Basics - Anfänger-Themen 7
F Mehrere Server Sockets in einer Anwendung Java Basics - Anfänger-Themen 9
T DoWhile Schleife über mehrere Mothoden Java Basics - Anfänger-Themen 5
B Methoden Mehrere ähnliche Methoden zusammenfassen Java Basics - Anfänger-Themen 24
E Mehrere Eingabezeilen gleichzeitig einlesen Java Basics - Anfänger-Themen 7
C Mehrere Zufallswerte Java Basics - Anfänger-Themen 4
M Dijkstra Algorithmus in Graphen auf mehrere verschiedene Knoten anwenden lassen Java Basics - Anfänger-Themen 11
R Error, wenn mehrere Clients gleichzeitig die Verbindung beenden Java Basics - Anfänger-Themen 16
F Mehrere Exceptions in einem Catch-Block abfangen Java Basics - Anfänger-Themen 12
O Datei in mehrere kleine Dateien umwandeln Java Basics - Anfänger-Themen 47
Henri Mehrere Ordner umbenennen Java Basics - Anfänger-Themen 11
E Mehrere Arrays addieren mit Übertrag Java Basics - Anfänger-Themen 13
B mehrere Werte mit scanner und while schleife einlesen, max berechnen bzw addieren Java Basics - Anfänger-Themen 2
J Mehrere paintComponenten in einem Programm Java Basics - Anfänger-Themen 0
F Mehrere Buttons mit einem ActionListener abdecken Java Basics - Anfänger-Themen 24
B Jeweils den Parent bekommen -> mehrere Ebenen Java Basics - Anfänger-Themen 2
javajoshi mehrere Threads: Methoden zentral unterbringen Java Basics - Anfänger-Themen 8
M Erste Schritte Mehrere eingaben in einer Line vergleichen (if equals...) Java Basics - Anfänger-Themen 6
L Mehrere Jars im Unterordner Java Basics - Anfänger-Themen 2
L LibGDX - mehrere Screens Java Basics - Anfänger-Themen 1
J Sudoku mehrere Lösungen Java Basics - Anfänger-Themen 29
F Mehrere Instanzen der Klasse A EINER Instanz der Klasse B übergeben Java Basics - Anfänger-Themen 3
T Mehrere JFrames gleichzeitig öffnen Java Basics - Anfänger-Themen 6
O Erste Schritte Scanner mehrere male benutzen (Konsole) Java Basics - Anfänger-Themen 7
S mehrere If Bedingungen Java Basics - Anfänger-Themen 5
F Mehrere Zeilen zu einer Zeile zusammenfügen und in eine Datei schreiben Java Basics - Anfänger-Themen 1
B Mehrere Zahlen speichern Java Basics - Anfänger-Themen 60
M mehrere extends? Java Basics - Anfänger-Themen 19
N Datei Zeilenweise einlesen, Ausgabe mehrere Arrays Java Basics - Anfänger-Themen 7
C ButtonController löst mehrere Methoden aus Java Basics - Anfänger-Themen 5
D JPanel mehrere Formen zeichnen Java Basics - Anfänger-Themen 5
B Timer mehrere Male ausführen Java Basics - Anfänger-Themen 4
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
F mehrere eingegebene Zahlen mit Zahlen von 1-9 multiplizieren Java Basics - Anfänger-Themen 18
F Mehrere Konstruktoren? Wofür? Java Basics - Anfänger-Themen 21
J Mehrere Eingabefelder programmiert (Zeigt Fehler an) Java Basics - Anfänger-Themen 6
Jinnai4 Mehrere Textfelder überprüfen Java Basics - Anfänger-Themen 16
N Mehrere Forms auf einem Panel Java Basics - Anfänger-Themen 6
Tommy Nightmare Variable auf mehrere Ungleichheiten prüfen Java Basics - Anfänger-Themen 18
D Mehrere Objekte in ein Objekt zusammenfassen Java Basics - Anfänger-Themen 16
D Input/Output Mehrere Befehle nacheinander ausführen Java Basics - Anfänger-Themen 20
K Mehrere Objekte anlegen Java Basics - Anfänger-Themen 23
N Integers aus Textdatei auslesen und mehrere Arrays erstellen Java Basics - Anfänger-Themen 9
S Verständnis - Frage mehrere SQL Statements in While Schleife Java Basics - Anfänger-Themen 0
J MVC Pattern, mehrere Controller/Views/Models Java Basics - Anfänger-Themen 0
J Mehrere IF Anweisungen und dazugehörige ELSE Java Basics - Anfänger-Themen 6
I Klassen Mehrere Java Klassen in einer .java Datei Java Basics - Anfänger-Themen 7
V Mehrere Dateien aus JFileChooser in eine ArrayList speichern Java Basics - Anfänger-Themen 2
F Mehrere Konstruktoren Java Basics - Anfänger-Themen 10
A Mehrere Radiobuttons Java Basics - Anfänger-Themen 3
B Klassen Mehrere Objekte mit Schleife erstellen - How? Java Basics - Anfänger-Themen 1
T Mehrere Methoden in der main-Methode verknüpfen und aufeinander anwenden Java Basics - Anfänger-Themen 2
V OOP Aufnahme von Dreiecken in ein/mehrere Objekte Java Basics - Anfänger-Themen 0
Q OOP Mehrere Instanzen auf ein Feld Java Basics - Anfänger-Themen 13
C Klasse auf mehrere Objekte zugreifen lassen Java Basics - Anfänger-Themen 26
G Mehrere If-else-Sätze der Reihe nach durchlaufen lassen Java Basics - Anfänger-Themen 2
K Mehrere String.valueOf() kürzer schreiben / "packen"? Java Basics - Anfänger-Themen 2
F String mehrere male ausgeben? Java Basics - Anfänger-Themen 4
H wie mehrere variablen in einfacher for-schleife? Java Basics - Anfänger-Themen 2
H möglichkeiten für for-schleife? (mehrere ausgangsvariablen?) Java Basics - Anfänger-Themen 9
M PdfBox - mehrere Formularseiten Java Basics - Anfänger-Themen 2
Z Mehrere XML-Dateien zu einer zusammenfügen Java Basics - Anfänger-Themen 3
M GUI- mehrere Komponenten auf Container adden Java Basics - Anfänger-Themen 2
I Erste Schritte Resource Bundle - Alles in einem File oder mehrere? => Faktor Performance Java Basics - Anfänger-Themen 2
F Methoden split() - Mehrere Zeichen Java Basics - Anfänger-Themen 5
F Erste Schritte Mehrere nextInt() Eingaben nebeneinander ausgeben Java Basics - Anfänger-Themen 12
A mehrere Panels in eigenen Klasssen in einem Frame Java Basics - Anfänger-Themen 16
A Mehrere 100.000 Elemente verlgeichen Java Basics - Anfänger-Themen 8
T Compiler-Fehler Mit Array und "for" mehrere ImageIcon erstellen Java Basics - Anfänger-Themen 7
N Mehrere berechnungen auf einem Button legen? Java Basics - Anfänger-Themen 19
F Swing Applet: mehrere Komponenten hinzufügen Java Basics - Anfänger-Themen 1
F Speicherlast mehrere GB durch kleine png files? Java Basics - Anfänger-Themen 1
C Mehrere Tasten beim KeyListener gleichzeitig lesen Java Basics - Anfänger-Themen 2
M Mehrere Variabeln zusammenfassen Java Basics - Anfänger-Themen 4
M Erste Schritte mehrere Objekte aus einer Klasse Java Basics - Anfänger-Themen 4
L String extrahieren mit Regular Expression über mehrere Zeilen hinweg Java Basics - Anfänger-Themen 1
B Mehrere Klassen miteinander kommunizieren lassen Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben