Endergebnis einer rekursiven Methode

timbeau

Gesperrter Benutzer
Hallo und guten Abend zusammen.

Ich lese hier regelmäßig aber habe in der SuFu leider keine passende Antwort gefunden.

Mein Problem ist das Folgende:
Ich habe aus Spaß ein Programm geschrieben, welches mir ein Sudoku füllt. Dieses lese ich über eine Swing-Gui ein. Um die Ausgabe ebenfalls in dieser Gui anzuzeigen habe ich mir gedacht, dass ich ja die 81 JTextfields neu befülle. Dabei stellt sich mir die Frage die ich bisher nicht lösen konnte (wahrscheinlich Brett vorm Kopf), wie bekomme ich das letzte Ergebnis der folgenden Methode:

Java:
Aufruf (Sudoku)
Prüfen ob das Sudoku gelöst ist und dann dieses Feld zurückgeben
Wenn nicht eine Zahl einfügen und mit dem neuen Feld aufrufen und return Null

Wie kann ich in meiner Gui nun auf die Lösung des Sudokus warten. Wenn ich schreibe

Java:
while(true) {
if(Lösung = rekursiveMethode(Sudoku)!= null) {
Zeichne GUI
}



generiert er mir natürlich endlos viele Methoden. Direkt Lösung = rekursiveMethode gibt mir ja ein Null zurück.

Vermutlich ist es ganz einfach. Sollte ich Informationen vergessen/unterschlagen haben, nicht schimpfen, ich liefere sie nach ;-)

Danke schonmal
 

Cola_Colin

Top Contributor
Die Methode zum Lösen in einen Thread verpacken und darauf warten, das der Fertig wird ?
Deine Lösungsmethode wird doch wohl nicht direkt mit dem UI als Datenquelle arbeiten ?
 

XHelp

Top Contributor
Wo hast du denn diesen Lösungsansatz her? Es sieht verdächtig dannach aus, als ob du den ganzen Baum aufbaust, dann sollte es ähnlich aussehen wie:
Code:
boolean sudokuLoesbar(Spielfeld) {
  Keine Züge möglich?
    Ist die Lösung korrekt?
      gib true zurück

  für alle Möglichen Züge:
    neuesSpielfeld = machDenZug()
    wenn (sudokuLoesbar(neuesSpielfeld))
      dann gib true zurück

  gib false zurück
}

Aber ich bin mir sicher, dass es effizientere Lösungsansätze gibt.
 

timbeau

Gesperrter Benutzer
Das Programm hab ich eigentlich angefangen um mich in die Swing-Programmierung einzuarbeiten. Ist dann allerdings doch mehr in den reinen 'Java'-Bereich abgerutscht.

Das komplette Programm baut ein Sudoku aus den einzelnen Feldern(eigene Klasse) die jeweils für sich ihre möglichen Zahlen prüfen und hält sie in einem Array vor.

Meine rekursive-Methode setzt halt die Zahlen aus dem kürzesten Array ein, prüft, berechnet die Felder neu, setzt wieder die Zahl aus dem kürzesten Array ein und geht rekursiv zurück wenn sie irgendwo hängt bzw wenn es keine Lösung gibt, sagt sie das auch.

Und das ganze funktioniert auch. Auf der Konsole bekomme ich das gelöste Sudoku zurück wenn ich es per Gui eingebe und die rekursive Methode starte. Ich gehe allerdings alle Äste des Baums lang bis ich an eine Sackgasse komme. Aber bei 81 Feldern ist das mE vernachlässigbar.

Bzgl Threads habe ich mir auch schon gedacht. Aber der Thread muss ja auch irgendwie merken, dass die rekursive Methode zu Ende gerechnet hat aber eben nur dann wenn eine Lösung gefunden wurde und sich dann auf jeden Fall beenden. Meine Methode gibt nämlich alle(?) möglichen Lösungen zurück, wenn ich also nur 1 Zahl eingebe spuckt er mir dutzende unterschiedliche Sudokus aus. Das ist zwar nett aber muss ja nicht sein. Jetzt muss also der Thread beendet werden und das gelöste Sudoku zurückgeben. Zusätzlich muss der main-thread ja warten. Und in welche Klasse muss der Thread am besten? In die der GUI oder in die Klasse des Sudokufeldes welches alle weiteren Operationen steuert.

Wäre schön, wenn ihr mir hier weiterhelfen könntet.
 
M

Marcinek

Gast
Hallo,

sobald der Thread zu ende ist löst er ein Ereignis aus: (Action)

Der dazugehörige ActionListener macht dann irgentwas damit. Alternativ ändert der Thread dann entspechend die UI ab um ddas Ergebnis darzustellen.

Ein Thread wird dann einfach beendet, wenn sein Code komplett ausgeführt worden ist.

Blockierende aufrufe halten alles an und es wird gerechnet, bis es fertig ist.

Möchtest du jeden rekursiven aufruf in einem Thread starten? - So funktionieren Rekursionen nicht.

Jeder Aufruf einer Rekursion blockiert und es wird intern duzende verweise (Rücksprungspunkte) generiert, die bei dem letzten aufruf der Rekursion zurückgesprungen werden.

Gruß,

Martin
 
Zuletzt bearbeitet von einem Moderator:

timbeau

Gesperrter Benutzer
Nein, ein Thread für die rekursive Methode. Wie kann ich aber den Thread also nun wenn er fertig ist dazu veranlassen eine Gui zu ändern mit dem Ergebnis des "letzten" Aufrufs der rekursiven Methode?

Wäre eine Möglichkeit eine Variable außerhalb des Threads zu überschreiben bei gelöstem Sudoku und nach Beendigung des Threads einfach diese auslesen?

Muss ich morgen mal testen.
 
M

Marcinek

Gast
Entweder du gibst dem Thread eine referenz auf deine GUI und er stellt dir das Ergebis dann dar.

Oder eine Referenz auf das Model und bei aktualisierung des Models => Aktualisierung der GUI.

trivial.
 

timbeau

Gesperrter Benutzer
Vielleicht drücke ich mich undeutlich aus oder es ist für euch zu einfach ;) . Ich habe eine unvorhersehbare Menge an Rückgabewerten. Irgendwo in diesem Baum findet meine Methode nun eine Lösung. Diese möchte ich sofort zurückgeben und die Methode inkl. aller weiteren rekursiven Aufrufe beenden. Kann ich sowas aufrufen:

Thread startet Methode einer Klasse und die Methode bricht mit System.exit(X) ab?
 

XHelp

Top Contributor
So läuft Rekursion nicht ab. Du könntest natürlich es etwas abändern, z.B.
Code:
rek() {
  bei Abbruchbedingung: rufe rekZuEnde(ergebnis) auf
  ansonsten rek();
Wenn du fertig bist, dann wird eben eine Methode aufgerufen, der Rückgabewert wird dabei ignoriert.
 

timbeau

Gesperrter Benutzer
Hey danke. Das klingt gut.

Aber bzgl "so läuft Rekursion nicht". Wenn ich einen Baum durchgehe mach ich doch auch nichts anderes. Ob ich die Ergebnisse nun sammle oder wie beim "Rucksackproblem" bzw Backtracking irgendwo halt mache ist doch im Prinzip egal. Bitte um Erläuterung ;)
 

XHelp

Top Contributor
Naja, beim Backtraing wird ja auch ein Wert zurückgegeben.
Du kannst ja eine rekursive Methode schreiben, der du ein unvollständiges Sudoku übergibst und sie dir ein vollständiges zurückliefert, falls möglich.
Dann musst du auch nicht den Code bis zum Unmöglichen ineinander verstricken.
 

timbeau

Gesperrter Benutzer
Genau das tu ich hier. Die Funktion ruft sich immer mit dem "neuen" Sudoku auf. Und wenn das Sudoku gelöst ist, möchte ich eine Meldung bekommen bzw das Sudoku zurück. Solange keine Lösung gefunden wurde bzw ganz am Ende gebe ich NULL zurück.

Okay, meine Lösung ist vielleicht nicht perfekt aber reicht. SObald eine Lösung gefunden wurde, wird diese in eine Klassenvariable geschrieben. Am Anfang der backtrack-Methode wird diese überprüft und bei NotNull wird returned. Damit laufen alle noch offenen Äste ins nichts und die Methode hört schnell auf.
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
ixChronos Letzten 4 Ziffern einer großen Zahl ausgeben Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
B Kommunikation mit Seriellen Schnittstellen + Integration einer lib Java Basics - Anfänger-Themen 1
A Daten aus einer HashMap aus einer DB speichern und mit neuen Werten vergleichen Java Basics - Anfänger-Themen 8
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
M Radius von einer ellipse bestimmen Java Basics - Anfänger-Themen 7
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
M Zufallszahl generieren mit einer linken und rechten Grenze Java Basics - Anfänger-Themen 3
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
M Spezifischen Wert einer Zeile aus .txt Datei entnehmen Java Basics - Anfänger-Themen 15
B Popups mit Klicksabfangen zumAusfüllen einer .ods Datei Java Basics - Anfänger-Themen 0
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
H Kapselung protected aber in einer Kindklasse nicht zugänglich Java Basics - Anfänger-Themen 5
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
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
Saiko Zeilen einer Datei einlesen Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
sserio Prüfziffer einer ISBN Nummer herrausfinden. Java Basics - Anfänger-Themen 14
J Benennung einer mir unbekannten Java - Ausdrucksweise Java Basics - Anfänger-Themen 5
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Wie gebe ich den Pfad zu einer Datei an, die in einem Ordner in Eclipse ist? Java Basics - Anfänger-Themen 1
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
J int innerhalb einer Datei ändern Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Neuling47 Ich zerbreche mit den kopf an einer Aufgabe Java Basics - Anfänger-Themen 61
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
M Wie kann ich den Index i von einer LinkedList überprüfen? Java Basics - Anfänger-Themen 36
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
javapingu Jeglichen Inhalt einer Textdatei nach Zeile n löschen Java Basics - Anfänger-Themen 8
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
P Iterieren mit einer Foreach in Lambdaschreibweise und Counter. Java Basics - Anfänger-Themen 1
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2
M Wie richte ich eine Diagonale an Robotern in einer World ein? Java Basics - Anfänger-Themen 15
YAZZ BlueJ Bewegung einer Figur im Kreis Java Basics - Anfänger-Themen 4
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
B GUI extension mit einer Liste verbinden Java Basics - Anfänger-Themen 1
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S Hilfe bei Programmierung einer Hotelabrechnung Java Basics - Anfänger-Themen 5
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8
J if-Schleife innerhalb einer if-Schleife wird in der Konsole nicht gelesen Java Basics - Anfänger-Themen 4
D Grösste Zahl in einer Folge herausfinden. (ULAM) Java Basics - Anfänger-Themen 9
Ameise04 Variablen Inhalt einer Variable im Code verwenden? Java Basics - Anfänger-Themen 9
I Array einer Methode wiedergeben Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben