Java :: Aufgabe #87 :: Lösung #1

1 Lösung Lösung öffentlich
#87

Das Damenproblem (Teil I)

Fortgeschrittener - Java von ElPapito - 07.05.2015 um 11:42 Uhr
Das klassische Damenproblem besteht aus einem 8x8 Schachfeld und 8 Damen.
Die Aufgabe besteht darin die 8 Damen so zu positionieren, dass sie sich gegenseitig nicht bedrohen, d.h. es dürfen keine zwei Damen in der gleichen Zeile/Spalte/Diagonale stehen.

Schreibe ein kleines Programm, welches ausgibt wie viele Lösungen existieren.
#1
vote_ok
von ElPapito (2690 Punkte) - 07.05.2015 um 20:50 Uhr
Quellcode ausblenden Java-Code

/**
 * @author ElPapito
 * @date 07.05.2015
 */

public class DasDamenproblem {

	public static void main(String[] args) {
		boolean[][] queen = new boolean[8][8];
		int counter = solutions(queen, 0);
		System.out.println(counter);
	}

	private static int solutions(boolean[][] queen, int row) {
		if (row == queen.length) {
			return 1;
		}

		int counter = 0;
		for (int col = 0; col < queen.length; col++) {
			if (!isPositionSave(queen, row, col)) {
				continue;
			}

			queen[row][col] = true;
			counter += solutions(queen, row + 1);
			queen[row][col] = false;
		}

		return counter;
	}

	public static boolean isPositionSave(boolean[][] queen, int row, int col) {

		for (int i = 0; i < row; i++) {
			int dC = row - i;
			// Teste Spalte
			if (queen[i][col]) {
				return false;
			}
			// Teste linke Diagonale
			if (col - dC >= 0 && queen[i][col - dC]) {
				return false;
			}
			// Teste rechte Diagonale
			if (col + dC < queen.length && queen[i][col + dC]) {
				return false;
			}
		}

		return true;
	}

}

Kommentare:

Für diese Lösung gibt es noch keinen Kommentar

Bitte melden Sie sich an um eine Kommentar zu schreiben.
Kommentar schreiben