Fillomino ist ein Puzzle, bei dem Sie ein Gitter mit Polyomino füllen . Jedes Polyomino ist ein Bereich zusammenhängender Zellen. Die Rasterdarstellung zeigt, welche Polyomino-Größe jede Zelle bedeckt. Zum Beispiel würde ein Pentomino (5) wie 5
in jeder der fünf zusammenhängenden Zellen gezeigt (siehe unten). Zwei gleich große Polyominos können sich keinen Rand teilen, sondern dürfen diagonal angrenzen.
Für jedes Rätsel müssen Sie eine Reihe von Angaben machen und die verbleibenden Felder ausfüllen. Ein einfaches Beispiel Puzzle und Lösung:
Ihre Aufgabe: Lösen Sie ein quadratisches Rätsel und geben Sie die Antwort aus. Die Eingabe kann über stdin, ein einzelnes Befehlszeilenargument oder eine Textdatei erfolgen. Die Eingabe erfolgt als Ganzzahl n
, gefolgt von jeweils n
einer n
Ziffernreihe. Leere Zellen werden als Punkte ( .
) angegeben. Für das obige Beispielpuzzle wäre es:
5
3..66
5.4.6
.54.6
.1.6.
..312
Die Ausgabe ist das Rätsel gelöst, da auf n
Zeilen von n
Ziffern, auf Konsole oder Textdatei:
33366
55446
55466
51462
33312
Wenn das Puzzle nicht gültig ist, wird ausgegeben 0
. Ein Puzzle kann ungültig sein, wenn die Eingabe fehlerhaft ist oder es keine Lösung gibt. Wenn es mehrere Lösungen gibt, können Sie eine oder alle ausgeben.
Da jede Zelle durch eine einzelne Ziffer dargestellt wird, bestehen alle Puzzlespiele aus Polyominoen der Größe 9
und darunter. Wenn es nicht möglich ist, ohne größere Polyominos zu lösen, halten Sie es für ungültig.
Gültige Antworten lösen ein bestimmtes Rätsel und geben Lösungen nicht einfach in Testfällen aus. Keine externen Ressourcen, sei es online oder lokal. Wenn es geschieht mit einem eingebauten in Fillomino Lösung Funktion eine Sprache zu sein, können Sie es nicht verwenden können. Kurz gesagt, fair spielen .
Testfall:
Eingang:
9
..21.3..5
.5...5..5
.1.44.334
...53.4..
2.3.3..5.
1.15.5.15
..45..1..
.24.53.53
....2....
Ausgabe (eine mögliche Lösung):
322133315
355445555
315443334
235531444
233135551
141535515
344553155
324553553
321223133
Denken Sie daran, dass einige Polyominos keine bestimmten Zahlen haben und einige mehr als eine. Es gibt keine Eins-zu-Eins-Beziehung zwischen der Anzahl der Gaben und der Anzahl der Polyominos.
Punktzahl ist Standard-Code-Golf, Größe des Programms in Bytes.
quelle
Antworten:
4882 Zeichen - Java
Keine sehr gute Lösung (dh 4800 Zeichen sind keine guten Tipps) Könnte ein bisschen besser sein, wenn noch 1 oder 2 Debug-Druckzeilen vorhanden sind. Ich denke, ich kann noch einiges an nutzlosem / optimiertem Code reduzieren.
Nachdem ich Polyominoes noch nie zuvor gesehen hatte, las ich nach, was sie sind, und ohne mir Gedanken über das Lösen von Algorithmen zu machen, machte ich mir nur meine eigenen (ziemlich langsamen).
Verwendet im Grunde viel Rekursion ... Findet ein unvollständiges Polyomino und versucht es zu vervollständigen. Findet eine leere Stelle, durchläuft alle Felder in der Tasche mit den Schleifen 1-9 und setzt diese Tasche auf diesen Wert. Wenn das Fach vollständig ist, versucht es, ein anderes Fach zu finden, und wiederholt dies, bis es fertig ist. Ich konnte es für ein Raster der Größe 9 nicht zum Laufen bringen ... Ich habe mindestens eine Optimierung im Sinn, die es in einer angemessenen Zeit für 9 zum Laufen bringen könnte. Könnte versuchen, dies bald zu implementieren.
quelle