Java - Enums

Karlter

Mitglied
Java:
public enum Direction {

    NORTH, SOUTH, EAST, WEST;

        public Direction opposite () {
            switch (this) {
                case NORTH:
                    return SOUTH;
                case SOUTH:
                    return NORTH;
                case EAST:
                    return WEST;
                case WEST:
                    return EAST;
                default:
                    return null;
            }
        }
    }


public class MzeSlv {

    public static SolutionStep findExit(Room currentRoom) {
        if (currentRoom.isExit()) {
            return new SolutionStep(null, null);
        }


        currentRoom.markVisited();

        for (Direction direction : Direction.values()) {
            Room nextRoom = currentRoom.getRoom(direction);
            if (nextRoom != null && !nextRoom.isVisited()) {
                SolutionStep result = findExit(nextRoom);
                if (result != null) {
                    return new SolutionStep(direction, result);
                }
            }
        }

        return null;
    }
}


public class Room {

    private final Room[] rooms = new Room[4];
    private boolean exit;
    private boolean visited = false;

    public Room(Room north, Room east, Room south, Room west, boolean exit) {
        this.exit = exit;
        rooms[Direction.NORTH.ordinal()] = north;
        rooms[Direction.EAST.ordinal()] = east;
        rooms[Direction.SOUTH.ordinal()] = south;
        rooms[Direction.WEST.ordinal()] = west;

        if (north != null) {
            assert north.rooms[Direction.SOUTH.ordinal()] == null;
            north.rooms[Direction.SOUTH.ordinal()] = this;
        }
        if (east != null) {
            assert east.rooms[Direction.WEST.ordinal()] == null;
            east.rooms[Direction.WEST.ordinal()] = this;
        }
        if (south != null) {
            assert south.rooms[Direction.NORTH.ordinal()] == null;
            south.rooms[Direction.NORTH.ordinal()] = this;
        }
        if (west != null) {
            assert west.rooms[Direction.EAST.ordinal()] == null;
            west.rooms[Direction.EAST.ordinal()] = this;
        }
    }

    public Room getRoom(Direction d) {
        return rooms[d.ordinal()];
    }

    public boolean isExit() {
        return exit;
    }

    public void markVisited() {
        this.visited = true;
    }

    public boolean isVisited() {
        return visited;
    }
}


public class SolutionStep {
    private final Direction direction;
    private final SolutionStep next;

    public SolutionStep(Direction direction, SolutionStep next) {
        this.direction = direction;
        this.next = next;
    }

    public SolutionStep next() {
        return next;
    }

    public Direction getDirection() {
        return direction;
    }


}

In dieser Aufgabe sollen Sie sich mit Enum befassen und Enum#ordinal() verwenden.

Schreiben Sie dazu ein Programm, das den Weg durch einen Irrgarten findet.

Das Enum Direction definiert Konstanten für die vier Richtungen (Direction.NORTH, Direction.EAST, Direction.SOUTH und Direction.WEST). Zusätzlich gibt es eine Methode Direction#opposite() die die gegensätzliche Richtung zurück gibt. (NORTH ↔↔ SOUTH bzw. EAST ↔↔ WEST).

Der Irrgarten wird durch eine Klasse Room repräsentiert, welcher bis zu vier Verbindungen zu anderen Räumen hat. Room hat einen Konstruktor Room(Room north, Room east, Room south, Room west, boolean exit). Dieser erzeugt einen neuen Raum mit angrenzenden Räumen in die Richtungen Direction.NORTH, Direction.EAST, Direction.SOUTH und Direction.WEST. null wird für (noch) keinen Raum verwendet. Nutzen Sie Enum#ordinal() von Direction um die Räume in einem Array (rooms) zu halten. Die übergebenen Räume werden so aktualisiert, dass am Ende des Konstruktoraufruf der Weg zurück wieder zu diesem Raum führt. Z.B. muss dieser Raum im Süden von dem Raum sein, der als north übergeben wurde. Stellen Sie mit assert sicher, das beim Aktualisieren keine vorhandenen Verbindungen überschrieben werden. Der boolean gibt an, ob der Raum ein Ausgang ist. Mit der Methode Room getRoom(Direction d) wird der Raum zurückgegeben, der in die angegebene Richtung liegt; sonst null. Die Methode boolean isExit() gibt zurück, ob der Raum ein Ausgang ist.

Die Funktion SolutionStep findExit(Room currentRoom) in MazeSolver bestimmt einen Weg aus dem Irrgarten heraus. Das Ergebnis wird in einzelnen Schritten angegeben. SolutionStep hat zwei Methoden (Direction getDirection() und SolutionStep next()) und wird wie folgt interpretiert: Wenn getDirection() null zurückgibt, ist der aktuelle Raum der Ausgang. Ansonsten ist dort angegebenen, in welche Richtung der aktuelle Raum verlassen werden muss. next() beinhaltet dann die Anweisung für den nächsten Raum. Beginn der Lösung ist in start. Z.B: Rückgabe (direction=null, next=null) heißt, der Startraum ist ein Ausgang. Rückgabe (direction=WEST, next=(direction=NORTH, next=(direction=null, next=null))) heißt, nach Westen, nach Norden und dort ist der Ausgang. Gibt es gar keinen Ausweg, wird null zurückgegeben. Jeder Irrgarten wird nur ein einziges mal gelöst.


Eventuell hat ja jemand Zeit und Lust sich hier mal einzulesen und mir gegebenenfalls einen Hinweis zu geben, wo hier noch Probleme auftreten könnten. In den vorgegebenen Testfällen sagt er mir, dass folgende Probleme auftreten:

Testfall · constructor_getRoomReturnsSameRoomAsPassed fehlgeschlagen​

Multiple Failures (2 failures) org.opentest4j.AssertionFailedError: Roome east was not found. org.opentest4j.AssertionFailedError: Roome south was not found.

Testfall · opposite fehlgeschlagen​

The opposite directions are checked. (4 failures) org.opentest4j.AssertionFailedError: south is opposite north org.opentest4j.AssertionFailedError: west is opposite east org.opentest4j.AssertionFailedError: north is opposite south org.opentest4j.AssertionFailedError: east is opposite west

Testfall · findExit_mazeSmall fehlgeschlagen​

expected: <Room@58d6cbe0> but was: <null>

Testfall · findExit_mazeManyExits fehlgeschlagen​

expected: <Room@51432332> but was: <Room@557cbdc2>

Testfall · findExit_mazeManyExits_endOnFirstExit fehlgeschlagen​

expected: <Room@4873b41> but was: <Room@216c8b5a>

Testfall · findExit_labyrinth fehlgeschlagen​

expected: <SOUTH> but was: <EAST>



Danke für Eure Mühe und Zeit!
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
tomzen Java Unterstützung für exel dateien installieren. Java Basics - Anfänger-Themen 2
Rookar java.lang.NoClassDefFoundError: org/json/JSONException Java Basics - Anfänger-Themen 2
Rookar Mit Button andere java öffnen Java Basics - Anfänger-Themen 4
F Java Object to Hashmap ? Java Basics - Anfänger-Themen 6
I Backend in Java und Ansicht von Dateien in statische HTML Seiten? Java Basics - Anfänger-Themen 15
R Input/Output Verwendung des Euro-Zeichens in Java Java Basics - Anfänger-Themen 7
I Push Nachrichten von JAVA EE App an Mobile App Java Basics - Anfänger-Themen 3
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

Ähnliche Java Themen

Neue Themen


Oben