queen problem | backtracking java
print single way of queen problem in java.
package Backtracking;
public class nQueenoneSol {
public static boolean isSafe(char chessBoard[][], int row, int col) {
// for check vertical
for (int i = row - 1; i >= 0; i--) {
if (chessBoard[i][col] == 'Q') {
return false;
}
}
// for heck up left diagonal
for (int i = row - 1, j = col - 1; i >= 0 && j >= 0; i--, j--) {
if (chessBoard[i][j] == 'Q') {
return false;
}
}
// for check down left diagonal
for (int i = row - 1, j = col + 1; i >= 0 && j < chessBoard.length; i--, j++) {
if (chessBoard[i][j] == 'Q') {
return false;
}
}
return true;
}
public static boolean nQueens(char chessBoard[][], int row) {
if (row == chessBoard.length) {
return true;
}
for (int j = 0; j < chessBoard.length; j++) {
if (isSafe(chessBoard, row, j)) {
chessBoard[row][j] = 'Q';
if (nQueens(chessBoard, row + 1)) {
return true;
}
chessBoard[row][j] = 'X';
}
}
return false;
}
public static void displayBoard(char chessBoard[][]) {
System.out.println("------------------");
for (int i = 0; i < chessBoard.length; i++) {
for (int j = 0; j < chessBoard.length; j++) {
System.out.print(chessBoard[i][j] + " ");
}
System.err.println();
}
}
public static void main(String[] args) {
int n = 5;
char chessBoard[][] = new char[n][n];
//for print X
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
chessBoard[i][j] = 'X';
}
}
if (nQueens(chessBoard, 0)) {
System.out.println("Solution Possible---->");
displayBoard(chessBoard);
}
}
}
output:
Solution Possible---->
------------------
Q X X X X
X X Q X X
X X X X Q
X Q X X X
X X X Q X