Problem beim Rätsellöser

L

Lillie

Gast
Hallo,
ich hoffe, ich habe das richtige Unterforum erwischt, falls nicht bitte ich um Verzeihung.
ich programmiere momentan ein Programm, das mir meine Mosaik-Rätsel lösen soll, da ich das Lösungsheft dazu nicht mehr finden kann und gerne wissen will, ob meine Lösungen stimmen.
Anfangs habe ich es mit Brute-Force versucht, aber das geht nur bis 5*5 Felder gut, bei 15*15 Feldern dauert es zu lange.

Erst einmal die Erklärung, was ich eigentlich machen will: Man hat Felder einer bestimmten Größe gegeben (z.B. 5*5) und am Rand stehen Zahlen (z.b. 2 1). Nun soll man die Kästchen des Felds schwarz anmalen. Und zwar so viele pro Zeile, wie am Rand steht. Zwischen 2 schwarzen Blöcken muss mindestens 1 weißes Feld sein.
Bei einer Zeile von 5 Kästchen mit den Zahlen 2 und 1 gibt es also folgende Möglichkeiten:
s s w s w
s s w w s
w s s w s

Mein Programm soll nun alle Möglichkeiten in eine LinkedList aus boolean[] speichern. Also pro Möglichkeit ein boolean[] an die LinkedList anhängen.

Problem: Je nachdem wie viele Zahlen ich im Zahlenarray gegeben habe, brauche ich unterschiedlich viele for-Schleifen (zumindest bei meiner jetzigen Implementierung). Das ist allerdings nicht schön, weil ich damit nicht alle Fälle abdecken kann und es bei vielen Zahlen sein kann, dass ich nicht genug Fälle abgedeckt habe. Ich poste mal den Code, den ich bisher habe, allerdings macht es glaube ich keinen Sinn ihn komplett zu ergänzen, weil er ja nicht sonderlich gut ist, aber damit ihr versteht, was ich machen will:

Java:
public static LinkedList<boolean[]> gibMoeglichkeiten(int felder,int zahlen[]){
		LinkedList<boolean[]> liste = new LinkedList<boolean[]>();
		if(zahlen.length == 1 && zahlen[0] == 0){
			return liste;
		}
		// eine Zahl
		if(zahlen.length == 1){
			for(int i = 0; i< felder; i++){
				boolean[] possible = new boolean[felder];
				for(int schwarz = 0; schwarz<zahlen[0]; schwarz ++){
					if(i+schwarz>= felder){
						return liste;
					}
					possible[i+schwarz] = true;
				}
				liste.add(possible);
			}		
		}
		// zwei Zahlen
		if(zahlen.length == 2){
			int maximum = felder-zahlen[1]-1;
			for(int i = 0; i< maximum; i++){
				// zweite Zahl 
				for(int j = i+zahlen[0] +1; j< felder; j++){
					boolean[] possible = new boolean[felder];
					// Hier habe ich jetzt aufgehört, weil es nicht sinnvoll ist das noch weiter auszuprogrammieren
				}
			}
		}
	}

Hat jemand eine Idee, wie ich das klüger machen kann, also so, dass ich keine von der Anzahl der Zahlen abhängige Anzahl an for-Schleifen benötige? Ich habe auch schon überlegt, ob das ganze vielleicht irgendwie rekursiv zu lösen ist, aber ich finde keine passende Möglichkeit...
Vielen Dank schon mal fürs Durchlesen, ich hoffe ihr könnt mir helfen

Lillie
 

Quaxli

Top Contributor
Hallo,
...
Erst einmal die Erklärung, was ich eigentlich machen will: Man hat Felder einer bestimmten Größe gegeben (z.B. 5*5) und am Rand stehen Zahlen (z.b. 2 1). Nun soll man die Kästchen des Felds schwarz anmalen. Und zwar so viele pro Zeile, wie am Rand steht. Zwischen 2 schwarzen Blöcken muss mindestens 1 weißes Feld sein.
Bei einer Zeile von 5 Kästchen mit den Zahlen 2 und 1 gibt es also folgende Möglichkeiten:
s s w s w
s s w w s
w s s w s
...

Vielleicht wird Dir schneller geholfen, wenn Du weniger umständlich erklärst?
Langer Rede kurzer Sinn: Du möchtest ein Nonogramm lösen lassen.
 
L

Lillie

Gast
Danke, ich wusste nicht dass sowas Nonogramm heißt, nach dem Namen hab ich auch schon ewig gesucht. Also ja, ich möchte ein Nonogramm lösen. ;)
 

Marco13

Top Contributor
Rekursion ist vielleicht gar nicht so verkehrt. Ist jetzt nur straightforward hingeschrieben, da gibts sicher elegantere und vor allem effizientere Möglichkeiten
Java:
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;


public class Nonogram
{
	public static void main(String[] args)
	{
		int input[] = new int[]{ 2, 1, 2 };
		int size = 10;
		List<List<Boolean>> results = new ArrayList<List<Boolean>>();
		for (int spaces=0; spaces<size; spaces++)
		{
			appendSpaces(results, new ArrayList<Boolean>(), spaces, input, 0, size);
		}
		for (List<Boolean> result : results)
		{
			System.out.println(result);
		}
	}
	
	public static void appendSpaces(List<List<Boolean>> results, List<Boolean> currentList, int numSpaces, int input[], int index, int size)
	{
		currentList.addAll(Collections.nCopies(numSpaces, Boolean.FALSE));
		if (currentList.size() == size)
		{
			if (index == input.length)
			{
				results.add(currentList);
			}
			return;
		}
		else if (currentList.size() < size)
		{
			appendFields(results, new ArrayList<Boolean>(currentList), 0, input, index, size);
		}
	}
	
	private static void appendFields(List<List<Boolean>> results, List<Boolean> currentList, int numSpaces, int[] input, int index, int size)
	{
		if (index < input.length)
		{
			currentList.addAll(Collections.nCopies(input[index], Boolean.TRUE));
			index++;
			if (currentList.size() == size)
			{
				if (index == input.length)
				{
					results.add(currentList);
				}
				return;
			}
			else if (currentList.size() < size)
			{
				for (int spaces=1; spaces<=size-currentList.size(); spaces++)
				{
					appendSpaces(results, new ArrayList<Boolean>(currentList), spaces, input, index, size);
				}
			}
		}
	}

	
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
O Problem beim Aufrufen des Spiels von einem Menü Spiele- und Multimedia-Programmierung 7
G LIBGDX Problem beim resizen des Frames Spiele- und Multimedia-Programmierung 3
T LWJGL 2.9.2: Seltsamer Effekt beim Rendern (VertexShader Problem?) Spiele- und Multimedia-Programmierung 3
T Problem beim Aufbau des Spielfelds Spiele- und Multimedia-Programmierung 18
N Problem mit Kollisionsabfrage beim Fallen Jump & Run Spiele- und Multimedia-Programmierung 5
D Problem beim bewegen einer Figur Spiele- und Multimedia-Programmierung 2
K Problem beim Anzeigen von Bildern Spiele- und Multimedia-Programmierung 5
D Problem mit Überprüfung beim Lottospiel Spiele- und Multimedia-Programmierung 6
D Problem beim Öffnen einer PHP für eine Highscore Spiele- und Multimedia-Programmierung 5
aze Problem beim Laden von Obj File Spiele- und Multimedia-Programmierung 3
S Problem beim laden eines Bildes in einer Methode Spiele- und Multimedia-Programmierung 14
B Problem beim Programmieren von 4Gewinnt Spiele- und Multimedia-Programmierung 5
G Problem beim Zeichnen von LineArrays Spiele- und Multimedia-Programmierung 9
C Problem beim picken Spiele- und Multimedia-Programmierung 10
B Problem beim Programmieren Von Mühle Spiele- und Multimedia-Programmierung 6
B problem beim Memory Logik Spiele- und Multimedia-Programmierung 13
J Problem beim Instaliren Spiele- und Multimedia-Programmierung 8
N Rundenstrategiespiel - Problem beim Drehen eines Bildes Spiele- und Multimedia-Programmierung 18
C Graphische Benutzerschnittstelle, Problem beim Zeichnen Spiele- und Multimedia-Programmierung 4
A [HILFE] - Minecraft-Problem! Spiele- und Multimedia-Programmierung 1
C Plugin Problem Spiele- und Multimedia-Programmierung 2
J JLayer Problem Spiele- und Multimedia-Programmierung 1
Meeresgott LWJGL 3 Problem mit einer Texture Spiele- und Multimedia-Programmierung 4
G Low Poly 3D LWJGL Shader Problem Spiele- und Multimedia-Programmierung 4
G LIBGDX Texturen Problem Spiele- und Multimedia-Programmierung 1
C AutoClicker Problem Spiele- und Multimedia-Programmierung 2
S OOP Logik Problem Spiele- und Multimedia-Programmierung 5
G LIBGDX Viewport Problem Spiele- und Multimedia-Programmierung 3
J Problem mit Game Of Life Spiele- und Multimedia-Programmierung 3
N Problem mit 2D Spiel Spiele- und Multimedia-Programmierung 17
C Minecraft Minecraft Plugin Problem Spiele- und Multimedia-Programmierung 17
R Pong Spiel Problem Spiele- und Multimedia-Programmierung 1
V Problem mit BufferStrategy Spiele- und Multimedia-Programmierung 2
Streeber Problem mit Transparenz/TextDrawing in LWJGL/Slick2d (OpenGL) Spiele- und Multimedia-Programmierung 1
E A-Stern Algorithmus Problem und Implementierung einer Map Spiele- und Multimedia-Programmierung 6
W Generelles Problem: Entscheidungsfindung Spiele- und Multimedia-Programmierung 4
T Problem bei Kollisionsabfrage Spiele- und Multimedia-Programmierung 4
C Vier Gewinnt Problem mit Ordnerstruktur Spiele- und Multimedia-Programmierung 2
T Problem mit Eclipse (java)-(minecraft) Spiele- und Multimedia-Programmierung 3
I Textbasiertes Spiel - Umsetzungsfrage & Schleifen Problem Spiele- und Multimedia-Programmierung 26
M Sound Problem Spiele- und Multimedia-Programmierung 3
M Sound Engin Problem 2 Spiele- und Multimedia-Programmierung 2
J Problem bei der GUI - Zu viele Spielbretter Spiele- und Multimedia-Programmierung 2
D LWJGL gluLookAt "Umschauen" Problem Spiele- und Multimedia-Programmierung 0
D Problem mit Würfelanimierung in LWJGL Spiele- und Multimedia-Programmierung 7
C Zeldaklon Problem mit Wand-Kollision Spiele- und Multimedia-Programmierung 8
0 Boxen übereinander stapelt Problem Spiele- und Multimedia-Programmierung 5
D Textfield im Game ,Problem: while-Schleife Spiele- und Multimedia-Programmierung 3
R 2D platformer - enemy damage -> TIMER PROBLEM Spiele- und Multimedia-Programmierung 3
S LWJGL Kamera Problem - Alles verzerrt Spiele- und Multimedia-Programmierung 4
B LWJGL StackOverFlow Problem nach 30sekunden. (Pong) Spiele- und Multimedia-Programmierung 2
Seikuassi LWJGL-Problem Spiele- und Multimedia-Programmierung 2
L Minecraft Minecraft Plugin programmieren (Craftbukkit 1.7.2) Problem Spiele- und Multimedia-Programmierung 4
B Minecraft mehr Ram zuweißen Problem Spiele- und Multimedia-Programmierung 0
K Bukkit Plugin Problem Spiele- und Multimedia-Programmierung 3
Y Problem mit repaint() in run() Spiele- und Multimedia-Programmierung 2
X Kleines Problem mit Java Reflections und einem eigenen Eventhandler Spiele- und Multimedia-Programmierung 1
T Problem mit Kollisionsabfrage der NPC Spiele- und Multimedia-Programmierung 1
J Minecraft Problem mit dem JRE - Minecraft Spiele- und Multimedia-Programmierung 3
TheSorm Problem mit 2 classen NullPointerException Spiele- und Multimedia-Programmierung 1
S Problem mit 4 gewinnt(MinMax Algorithmus) Spiele- und Multimedia-Programmierung 2
N Problem in der Main.class Spiele- und Multimedia-Programmierung 1
J Blöcke, Hitboxen, Koolisionsabfrage - Problem Spiele- und Multimedia-Programmierung 8
S Problem mit 3d-Polygon Spiele- und Multimedia-Programmierung 2
A Problem mit Sound Spiele- und Multimedia-Programmierung 5
C Nxt Duell Problem Spiele- und Multimedia-Programmierung 4
F LWJGL Problem mit Erstellen eines Objekts und der Kamera Spiele- und Multimedia-Programmierung 5
ruerob Problem bei Fade-Out von Sounds Spiele- und Multimedia-Programmierung 3
L [Slick2D] Problem bei Speicherfreigabe Spiele- und Multimedia-Programmierung 2
M Bukkit Plugin Problem Spiele- und Multimedia-Programmierung 22
T Java3D Rendering Problem Spiele- und Multimedia-Programmierung 7
J Problem bei pixelgenauer Kollisionsabfrage Spiele- und Multimedia-Programmierung 10
F Problem mit dem Abspielen von byte[] (Audioprogrammierung) Spiele- und Multimedia-Programmierung 2
C Problem mit Abspielen von Audio-Dateien Spiele- und Multimedia-Programmierung 3
R Problem bei Farbe ändern/4Gewinnt Spiele- und Multimedia-Programmierung 5
R StringIndexOutOfBoundsException - Problem Spiele- und Multimedia-Programmierung 2
S Problem mit Sichtfeld/Licht in einem Raster Spiele- und Multimedia-Programmierung 5
G Acht-Damen-Problem HILFE! Spiele- und Multimedia-Programmierung 11
A TileMap KeyListener - Problem Spiele- und Multimedia-Programmierung 2
J Problem mit Threads Spiele- und Multimedia-Programmierung 8
S Problem mit Zeitsteuerung der Game Loop Spiele- und Multimedia-Programmierung 4
Fu3L Problem mit 3D Noise Spiele- und Multimedia-Programmierung 4
T Problem bei LinkedList / JPanel Spiele- und Multimedia-Programmierung 4
T Problem mit ClassLoader und LWJGL Spiele- und Multimedia-Programmierung 5
M Scrolling Repaint Problem Spiele- und Multimedia-Programmierung 2
Samake03 [Problem] layeredPane bzw. Viewport Spiele- und Multimedia-Programmierung 3
Helgon glTexParameter / glTexImage2D Problem Spiele- und Multimedia-Programmierung 11
T Jmonkey opengl problem Spiele- und Multimedia-Programmierung 13
M Problem mit Kamera (glMultMatrix (OpenGL/ LWJGL)/ Quaternionen) Spiele- und Multimedia-Programmierung 5
M Problem mit Gameserver / Datensynchronisation Spiele- und Multimedia-Programmierung 10
G Mein erstes minigame -> problem mit Methode Spiele- und Multimedia-Programmierung 3
X Geometry Wars Clone Problem Spiele- und Multimedia-Programmierung 4
H Problem mit JMonkeyEngine3 und OgreXML Spiele- und Multimedia-Programmierung 3
D [JOGL 2.0] Kleines Problem mit freier Flugsteuerung Spiele- und Multimedia-Programmierung 3
A JAVA3D TransformGroup <--> Group Problem Spiele- und Multimedia-Programmierung 3
U [JOGL 1.1.1a]Kleines Problem mit Text Overlays: Spiele- und Multimedia-Programmierung 19
T Problem mit JnR-Steuerung / KeyListener Spiele- und Multimedia-Programmierung 6
D Problem Mit Miensweeper Clone & rekursive Methode Spiele- und Multimedia-Programmierung 4
M Performance Problem bei BufferedImage Spiele- und Multimedia-Programmierung 7
T Problem mit Speicherverbrauch Spiele- und Multimedia-Programmierung 5

Ähnliche Java Themen

Neue Themen


Oben