#include<stdio.h>#include<stdlib.h>#include<stdbool.h>#define N 8boolisSafe(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;
}
voidprintSolution(int board[N][N]){
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++)
printf(" %d ", board[i][j]);
printf("\n");
}
}
voidsolveNQ(){
int board[N][N] = {0};
if (solveNQUtil(board, 0) == false) {
printf("Solution does not exist");
return;
}
printSolution(board);
}
intmain(){
solveNQ();
return0;
}