mirror of
https://hub.njuu.cf/TheAlgorithms/C-Plus-Plus.git
synced 2023-10-11 13:05:55 +08:00
Create nQueens.cpp
solved n queens problem
This commit is contained in:
parent
6376bf46af
commit
6b0b9c3f1a
124
backtracking/nQueens.cpp
Normal file
124
backtracking/nQueens.cpp
Normal file
@ -0,0 +1,124 @@
|
||||
#include<iostream>
|
||||
using namespace std;
|
||||
|
||||
bool isSafe(int arr[][4],int x,int y,int n){
|
||||
|
||||
// in column
|
||||
for(int i=0;i<n;i++){
|
||||
if(arr[i][y]==1){
|
||||
return false;
|
||||
}
|
||||
}
|
||||
// in row
|
||||
for(int j=0;j<n;j++){
|
||||
if(arr[x][j]==1){
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
int row = x;
|
||||
int col = y;
|
||||
|
||||
//left diagonal
|
||||
while(row>=0 && col>=0){
|
||||
if(arr[row][col]==1){
|
||||
return false;
|
||||
}
|
||||
row--;
|
||||
col--;
|
||||
}
|
||||
|
||||
row = x;
|
||||
col = y;
|
||||
|
||||
|
||||
// right diagonal
|
||||
while(row>=0 && col<n){
|
||||
if(arr[row][col]==1){
|
||||
return false;
|
||||
}
|
||||
row--;
|
||||
col++;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void printMatrix(int arr[][4],int n){
|
||||
for(int i=0;i<n;i++){
|
||||
for(int j=0;j<n;j++){
|
||||
if(arr[i][j] == 0)
|
||||
cout<<"_"<<" ";
|
||||
else
|
||||
cout<<"Q"<<" ";
|
||||
}
|
||||
cout<<endl;
|
||||
}
|
||||
cout<<endl;
|
||||
}
|
||||
|
||||
// row = starting row
|
||||
bool nQueen(int arr[][4],int n,int row){
|
||||
|
||||
// base case = if row > n ==> done
|
||||
if(row>=n){
|
||||
return true;
|
||||
}
|
||||
|
||||
// columns - elements in a particular row
|
||||
for(int j=0;j<n;j++){
|
||||
for(int k=0;k<n;k++){
|
||||
arr[row][k]=0;
|
||||
}
|
||||
if(isSafe(arr,row,j,n)){
|
||||
arr[row][j]=1;
|
||||
|
||||
printMatrix(arr,n);
|
||||
|
||||
if(nQueen(arr,n,row+1)){
|
||||
return true;
|
||||
}
|
||||
|
||||
arr[n][j]=0; // backtracking
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
|
||||
int main(){
|
||||
|
||||
int n = 4;
|
||||
|
||||
int arr[4][4];
|
||||
|
||||
// initializing all to 0
|
||||
for(int i=0;i<n;i++){
|
||||
for(int j=0;j<n;j++){
|
||||
arr[i][j]=0;
|
||||
}
|
||||
}
|
||||
cout<<"\nSTEPS : \n";
|
||||
printMatrix(arr,n);
|
||||
|
||||
for(int i=0;i<n;i++){
|
||||
// giving starting row i
|
||||
bool ans = nQueen(arr,n,i);
|
||||
|
||||
if(ans){
|
||||
cout<<"\nSolution : \n\n";
|
||||
printMatrix(arr,n);
|
||||
break;
|
||||
}
|
||||
else{
|
||||
cout<<"Solution doesn't exist\n";
|
||||
printMatrix(arr,n);
|
||||
cout<<endl<<endl;
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue
Block a user