#include<stdio.h>#include<stdbool.h>#define N 8voidprintSolution(int board[N][N]){
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++)
printf("%2d ", board[i][j]);
printf("\n");
}
}
boolisSafe(int board[N][N], int row, int col){
int i, j;
for (i = 0; i < col; i++)
if (board[row][i])
returnfalse;
for (i = row, j = col; i >= 0 && j >= 0; i--, j--)
if (board[i][j])
returnfalse;
for (i = row, j = col; j >= 0 && i < N; i++, j--)
if (board[i][j])
returnfalse;
returntrue;
}
boolsolveNQUtil(int board[N][N], int col){
if (col >= N)
returntrue;
for (int i = 0; i < N; i++) {
if (isSafe(board, i, col)) {
board[i][col] = 1;
if (solveNQUtil(board, col + 1))
returntrue;
board[i][col] = 0; // backtrack
}
}
returnfalse;
}
boolsolveNQ(){
int board[N][N];
for (int i = 0; i < N; i++)
for (int j = 0; j < N; j++)
board[i][j] = 0;
if (solveNQUtil(board, 0) == false) {
printf("Solution does not exist");
returnfalse;
}
printSolution(board);
returntrue;
}
intmain(){
solveNQ();
return0;
}