ProgrammierenUebung1/Uebung5/Aufgabe2/QueensProblem.java

50 lines
1.3 KiB
Java
Raw Normal View History

2023-12-04 19:55:59 +00:00
public class QueensProblem {
public static void main(String[] args) {
//Initialisiere Schachfeld 8x8
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;
}
}